]> git.proxmox.com Git - mirror_qemu.git/blame - monitor.c
nbd/server: fix NBD_CMD_CACHE
[mirror_qemu.git] / monitor.c
CommitLineData
9dc39cba
FB
1/*
2 * QEMU monitor
5fafdf24 3 *
9dc39cba 4 * Copyright (c) 2003-2004 Fabrice Bellard
5fafdf24 5 *
9dc39cba
FB
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22 * THE SOFTWARE.
23 */
e688df6b 24
d38ea87a 25#include "qemu/osdep.h"
8ec338ac 26#include "qemu/units.h"
511d2b14 27#include <dirent.h>
33c11879 28#include "cpu.h"
87ecb68b 29#include "hw/hw.h"
b4a42f81 30#include "monitor/qdev.h"
87ecb68b 31#include "hw/usb.h"
a2cb15b0 32#include "hw/pci/pci.h"
0d09e41a 33#include "sysemu/watchdog.h"
45a50b16 34#include "hw/loader.h"
022c62cb 35#include "exec/gdbstub.h"
1422e32d 36#include "net/net.h"
68ac40d2 37#include "net/slirp.h"
4d43a603 38#include "chardev/char-fe.h"
a5ed3525 39#include "chardev/char-io.h"
be933ffc 40#include "chardev/char-mux.h"
7572150c 41#include "ui/qemu-spice.h"
e35704ba 42#include "sysemu/numa.h"
83c9089e 43#include "monitor/monitor.h"
213dcb06 44#include "qemu/config-file.h"
0150cd81 45#include "qemu/readline.h"
28ecbaee 46#include "ui/console.h"
c751a74a 47#include "ui/input.h"
da27a00e 48#include "sysemu/block-backend.h"
87ecb68b 49#include "audio/audio.h"
76cad711 50#include "disas/disas.h"
9c17d615 51#include "sysemu/balloon.h"
1de7afc9 52#include "qemu/timer.h"
b3946626 53#include "sysemu/hw_accel.h"
1de7afc9 54#include "qemu/acl.h"
bdee56f5 55#include "sysemu/tpm.h"
452fcdbc 56#include "qapi/qmp/qdict.h"
cc7a8ea7 57#include "qapi/qmp/qerror.h"
15280c36 58#include "qapi/qmp/qnum.h"
fc81fa1e 59#include "qapi/qmp/qstring.h"
7b1b5d19
PB
60#include "qapi/qmp/qjson.h"
61#include "qapi/qmp/json-streamer.h"
62#include "qapi/qmp/json-parser.h"
02130314 63#include "qapi/qmp/qlist.h"
a9c94277 64#include "qom/object_interfaces.h"
0ab8ed18 65#include "trace-root.h"
31965ae2 66#include "trace/control.h"
bf957284 67#include "monitor/hmp-target.h"
6d8a764e 68#ifdef CONFIG_TRACE_SIMPLE
31965ae2 69#include "trace/simple.h"
22890ab5 70#endif
022c62cb 71#include "exec/memory.h"
63c91552 72#include "exec/exec-all.h"
03dd024f 73#include "qemu/log.h"
922a01a0 74#include "qemu/option.h"
48a32bed 75#include "hmp.h"
1de7afc9 76#include "qemu/thread.h"
b21631f3 77#include "block/qapi.h"
eb815e24
MA
78#include "qapi/qapi-commands.h"
79#include "qapi/qapi-events.h"
e688df6b 80#include "qapi/error.h"
43a14cfc 81#include "qapi/qmp-event.h"
eb815e24 82#include "qapi/qapi-introspect.h"
dc599978 83#include "sysemu/qtest.h"
d2528bdc 84#include "sysemu/cpus.h"
a5ed3525 85#include "sysemu/iothread.h"
f348b6d1 86#include "qemu/cutils.h"
6a5bd307 87
a4538a5c
JH
88#if defined(TARGET_S390X)
89#include "hw/s390x/storage-keys.h"
f860d497 90#include "hw/s390x/storage-attributes.h"
a4538a5c
JH
91#endif
92
9307c4c1
FB
93/*
94 * Supported types:
5fafdf24 95 *
9307c4c1 96 * 'F' filename
81d0912d 97 * 'B' block device name
9307c4c1 98 * 's' string (accept optional quote)
129be006 99 * 'S' it just appends the rest of the string (accept optional quote)
361127df
MA
100 * 'O' option string of the form NAME=VALUE,...
101 * parsed according to QemuOptsList given by its name
102 * Example: 'device:O' uses qemu_device_opts.
103 * Restriction: only lists with empty desc are supported
104 * TODO lift the restriction
92a31b1f
FB
105 * 'i' 32 bit integer
106 * 'l' target long (32 or 64 bit)
91162849
LC
107 * 'M' Non-negative target long (32 or 64 bit), in user mode the
108 * value is multiplied by 2^20 (think Mebibyte)
dbc0c67f 109 * 'o' octets (aka bytes)
5e00984a
KW
110 * user mode accepts an optional E, e, P, p, T, t, G, g, M, m,
111 * K, k suffix, which multiplies the value by 2^60 for suffixes E
112 * and e, 2^50 for suffixes P and p, 2^40 for suffixes T and t,
113 * 2^30 for suffixes G and g, 2^20 for M and m, 2^10 for K and k
fccfb11e
MA
114 * 'T' double
115 * user mode accepts an optional ms, us, ns suffix,
116 * which divides the value by 1e3, 1e6, 1e9, respectively
9307c4c1
FB
117 * '/' optional gdb-like print format (like "/10x")
118 *
fb46660e
LC
119 * '?' optional type (for all types, except '/')
120 * '.' other form of optional type (for 'i' and 'l')
942cd1f2
MA
121 * 'b' boolean
122 * user mode accepts "on" or "off"
fb46660e 123 * '-' optional parameter (eg. '-f')
9307c4c1
FB
124 *
125 */
126
c227f099 127typedef struct mon_cmd_t {
9dc39cba 128 const char *name;
9307c4c1 129 const char *args_type;
9dc39cba
FB
130 const char *params;
131 const char *help;
c3120f71 132 const char *flags; /* p=preconfig */
2b9e3576
MAL
133 void (*cmd)(Monitor *mon, const QDict *qdict);
134 /* @sub_table is a list of 2nd level of commands. If it does not exist,
135 * cmd should be used. If it exists, sub_table[?].cmd should be
136 * used, and cmd of 1st level plays the role of help function.
5f3d335f
WX
137 */
138 struct mon_cmd_t *sub_table;
bfa40f77 139 void (*command_completion)(ReadLineState *rs, int nb_args, const char *str);
c227f099 140} mon_cmd_t;
9dc39cba 141
f07918fd 142/* file descriptors passed via SCM_RIGHTS */
c227f099
AL
143typedef struct mon_fd_t mon_fd_t;
144struct mon_fd_t {
f07918fd
MM
145 char *name;
146 int fd;
c227f099 147 QLIST_ENTRY(mon_fd_t) next;
f07918fd
MM
148};
149
ba1c048a
CB
150/* file descriptor associated with a file descriptor set */
151typedef struct MonFdsetFd MonFdsetFd;
152struct MonFdsetFd {
153 int fd;
154 bool removed;
155 char *opaque;
156 QLIST_ENTRY(MonFdsetFd) next;
157};
158
159/* file descriptor set containing fds passed via SCM_RIGHTS */
160typedef struct MonFdset MonFdset;
161struct MonFdset {
162 int64_t id;
163 QLIST_HEAD(, MonFdsetFd) fds;
adb696f3 164 QLIST_HEAD(, MonFdsetFd) dup_fds;
ba1c048a
CB
165 QLIST_ENTRY(MonFdset) next;
166};
167
74358f2a 168typedef struct {
5fa737a4 169 JSONMessageParser parser;
f994b258
MA
170 /*
171 * When a client connects, we're in capabilities negotiation mode.
774a6b67
MA
172 * @commands is &qmp_cap_negotiation_commands then. When command
173 * qmp_capabilities succeeds, we go into command mode, and
174 * @command becomes &qmp_commands.
f994b258 175 */
635db18f 176 QmpCommandList *commands;
279f9e08
MA
177 bool capab_offered[QMP_CAPABILITY__MAX]; /* capabilities offered */
178 bool capab[QMP_CAPABILITY__MAX]; /* offered and accepted */
71da4667 179 /*
774a6b67
MA
180 * Protects qmp request/response queue.
181 * Take monitor_lock first when you need both.
71da4667
PX
182 */
183 QemuMutex qmp_queue_lock;
184 /* Input queue that holds all the parsed QMP requests */
185 GQueue *qmp_requests;
abe3cd0f
PX
186 /* Output queue contains all the QMP responses in order */
187 GQueue *qmp_responses;
74358f2a 188} MonitorQMP;
5fa737a4 189
afeecec2
DB
190/*
191 * To prevent flooding clients, events can be throttled. The
192 * throttling is calculated globally, rather than per-Monitor
193 * instance.
194 */
43a14cfc 195typedef struct MonitorQAPIEventState {
7de0be65
MA
196 QAPIEvent event; /* Throttling state for this event type and... */
197 QDict *data; /* ... data, see qapi_event_throttle_equal() */
afeecec2 198 QEMUTimer *timer; /* Timer for handling delayed events */
688b4b7d 199 QDict *qdict; /* Delayed event (if any) */
43a14cfc 200} MonitorQAPIEventState;
afeecec2 201
b9b03ab0
MA
202typedef struct {
203 int64_t rate; /* Minimum time (in ns) between two events */
204} MonitorQAPIEventConf;
205
87127161 206struct Monitor {
32a6ebec 207 CharBackend chr;
a7aec5da 208 int reset_seen;
731b0364 209 int flags;
df152fb9 210 int suspend_cnt; /* Needs to be accessed atomically */
48c043d0 211 bool skip_flush;
f91dc2a0 212 bool use_io_thread;
d9f25280
PX
213
214 /*
215 * State used only in the thread "owning" the monitor.
cab5ad86 216 * If @use_io_thread, this is @mon_iothread.
d9f25280
PX
217 * Else, it's the main thread.
218 * These members can be safely accessed without locks.
219 */
731b0364 220 ReadLineState *rs;
d9f25280 221
74358f2a 222 MonitorQMP qmp;
751f8cfe 223 gchar *mon_cpu_path;
097310b5 224 BlockCompletionFunc *password_completion_cb;
731b0364 225 void *password_opaque;
7717239d 226 mon_cmd_t *cmd_table;
238d9f34 227 QTAILQ_ENTRY(Monitor) entry;
dc7cbcd8
PX
228
229 /*
230 * The per-monitor lock. We can't access guest memory when holding
231 * the lock.
232 */
233 QemuMutex mon_lock;
234
235 /*
774a6b67 236 * Members that are protected by the per-monitor lock
dc7cbcd8 237 */
9409fc05 238 QLIST_HEAD(, mon_fd_t) fds;
dc7cbcd8
PX
239 QString *outbuf;
240 guint out_watch;
241 /* Read under either BQL or mon_lock, written with BQL+mon_lock. */
242 int mux_out;
87127161
AL
243};
244
774a6b67 245/* Shared monitor I/O thread */
cab5ad86
MA
246IOThread *mon_iothread;
247
248/* Bottom half to dispatch the requests received from I/O thread */
249QEMUBH *qmp_dispatcher_bh;
250
251/* Bottom half to deliver the responses back to clients */
252QEMUBH *qmp_respond_bh;
a5ed3525 253
6d2d563f
PX
254struct QMPRequest {
255 /* Owner of the request */
256 Monitor *mon;
257 /* "id" field of the request */
258 QObject *id;
1cc37471
MA
259 /*
260 * Request object to be handled or Error to be reported
261 * (exactly one of them is non-null)
262 */
6d2d563f 263 QObject *req;
1cc37471 264 Error *err;
6d2d563f
PX
265 /*
266 * Whether we need to resume the monitor afterward. This flag is
267 * used to emulate the old QMP server behavior that the current
268 * command must be completed before execution of the next one.
269 */
270 bool need_resume;
271};
272typedef struct QMPRequest QMPRequest;
273
2dbc8db0
LC
274/* QMP checker flags */
275#define QMP_ACCEPT_UNKNOWNS 1
276
095cb1bf 277/* Protects mon_list, monitor_qapi_event_state. */
d622cb58 278static QemuMutex monitor_lock;
095cb1bf 279static GHashTable *monitor_qapi_event_state;
238d9f34 280static QTAILQ_HEAD(mon_list, Monitor) mon_list;
095cb1bf 281
47451466
PX
282/* Protects mon_fdsets */
283static QemuMutex mon_fdsets_lock;
ba1c048a 284static QLIST_HEAD(mon_fdsets, MonFdset) mon_fdsets;
47451466 285
efb87c16 286static int mon_refcount;
7e2515e8 287
816f8925
WX
288static mon_cmd_t mon_cmds[];
289static mon_cmd_t info_cmds[];
9dc39cba 290
635db18f 291QmpCommandList qmp_commands, qmp_cap_negotiation_commands;
1527badb 292
62aa1d88 293__thread Monitor *cur_mon;
376253ec 294
c60bf339
SH
295static void monitor_command_cb(void *opaque, const char *cmdline,
296 void *readline_opaque);
83ab7950 297
9f3982f2
MA
298/**
299 * Is @mon a QMP monitor?
300 */
301static inline bool monitor_is_qmp(const Monitor *mon)
418173c7
LC
302{
303 return (mon->flags & MONITOR_USE_CONTROL);
304}
305
e3e977d4 306/**
774a6b67
MA
307 * Is @mon is using readline?
308 * Note: not all HMP monitors use readline, e.g., gdbserver has a
309 * non-interactive HMP monitor, so readline is not used there.
e3e977d4
PX
310 */
311static inline bool monitor_uses_readline(const Monitor *mon)
312{
313 return mon->flags & MONITOR_USE_READLINE;
314}
315
316static inline bool monitor_is_hmp_non_interactive(const Monitor *mon)
317{
318 return !monitor_is_qmp(mon) && !monitor_uses_readline(mon);
319}
320
6e8c5f4d
PX
321/*
322 * Return the clock to use for recording an event's time.
774a6b67
MA
323 * It's QEMU_CLOCK_REALTIME, except for qtests it's
324 * QEMU_CLOCK_VIRTUAL, to support testing rate limits.
6e8c5f4d
PX
325 * Beware: result is invalid before configure_accelerator().
326 */
327static inline QEMUClockType monitor_get_event_clock(void)
328{
6e8c5f4d
PX
329 return qtest_enabled() ? QEMU_CLOCK_VIRTUAL : QEMU_CLOCK_REALTIME;
330}
331
489653b5
MA
332/**
333 * Is the current monitor, if any, a QMP monitor?
334 */
335bool monitor_cur_is_qmp(void)
6620d3ce 336{
9f3982f2 337 return cur_mon && monitor_is_qmp(cur_mon);
6620d3ce
MA
338}
339
7060b478 340void monitor_read_command(Monitor *mon, int show_prompt)
731b0364 341{
183e6e52
LC
342 if (!mon->rs)
343 return;
344
731b0364
AL
345 readline_start(mon->rs, "(qemu) ", 0, monitor_command_cb, NULL);
346 if (show_prompt)
347 readline_show_prompt(mon->rs);
348}
6a00d601 349
7060b478
AL
350int monitor_read_password(Monitor *mon, ReadLineFunc *readline_func,
351 void *opaque)
bb5fc20f 352{
bcf5d19c 353 if (mon->rs) {
cde76ee1
AL
354 readline_start(mon->rs, "Password: ", 1, readline_func, opaque);
355 /* prompt is printed on return from the command handler */
356 return 0;
357 } else {
358 monitor_printf(mon, "terminal does not support password prompting\n");
359 return -ENOTTY;
360 }
bb5fc20f
AL
361}
362
6d2d563f
PX
363static void qmp_request_free(QMPRequest *req)
364{
cb3e7f08
MAL
365 qobject_unref(req->id);
366 qobject_unref(req->req);
1cc37471 367 error_free(req->err);
6d2d563f
PX
368 g_free(req);
369}
370
774a6b67 371/* Caller must hold mon->qmp.qmp_queue_lock */
6d2d563f
PX
372static void monitor_qmp_cleanup_req_queue_locked(Monitor *mon)
373{
374 while (!g_queue_is_empty(mon->qmp.qmp_requests)) {
375 qmp_request_free(g_queue_pop_head(mon->qmp.qmp_requests));
376 }
377}
378
774a6b67 379/* Caller must hold the mon->qmp.qmp_queue_lock */
6d2d563f
PX
380static void monitor_qmp_cleanup_resp_queue_locked(Monitor *mon)
381{
382 while (!g_queue_is_empty(mon->qmp.qmp_responses)) {
d43b1694 383 qobject_unref((QDict *)g_queue_pop_head(mon->qmp.qmp_responses));
6d2d563f
PX
384 }
385}
386
387static void monitor_qmp_cleanup_queues(Monitor *mon)
388{
389 qemu_mutex_lock(&mon->qmp.qmp_queue_lock);
390 monitor_qmp_cleanup_req_queue_locked(mon);
391 monitor_qmp_cleanup_resp_queue_locked(mon);
392 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
393}
394
395
6cff3e85
PB
396static void monitor_flush_locked(Monitor *mon);
397
f628926b
GH
398static gboolean monitor_unblocked(GIOChannel *chan, GIOCondition cond,
399 void *opaque)
400{
293d2a00
LE
401 Monitor *mon = opaque;
402
dc7cbcd8 403 qemu_mutex_lock(&mon->mon_lock);
6cff3e85
PB
404 mon->out_watch = 0;
405 monitor_flush_locked(mon);
dc7cbcd8 406 qemu_mutex_unlock(&mon->mon_lock);
f628926b
GH
407 return FALSE;
408}
409
774a6b67 410/* Caller must hold mon->mon_lock */
6cff3e85 411static void monitor_flush_locked(Monitor *mon)
7e2515e8 412{
f628926b 413 int rc;
e1f2641b
LC
414 size_t len;
415 const char *buf;
416
48c043d0
LC
417 if (mon->skip_flush) {
418 return;
419 }
420
e1f2641b
LC
421 buf = qstring_get_str(mon->outbuf);
422 len = qstring_get_length(mon->outbuf);
f628926b 423
a4cc73d6 424 if (len && !mon->mux_out) {
5345fdb4 425 rc = qemu_chr_fe_write(&mon->chr, (const uint8_t *) buf, len);
056f49ff
SP
426 if ((rc < 0 && errno != EAGAIN) || (rc == len)) {
427 /* all flushed or error */
cb3e7f08 428 qobject_unref(mon->outbuf);
e1f2641b 429 mon->outbuf = qstring_new();
f628926b
GH
430 return;
431 }
432 if (rc > 0) {
3b7c78c8 433 /* partial write */
e1f2641b 434 QString *tmp = qstring_from_str(buf + rc);
cb3e7f08 435 qobject_unref(mon->outbuf);
e1f2641b 436 mon->outbuf = tmp;
f628926b 437 }
6cff3e85 438 if (mon->out_watch == 0) {
32a6ebec 439 mon->out_watch =
5345fdb4 440 qemu_chr_fe_add_watch(&mon->chr, G_IO_OUT | G_IO_HUP,
32a6ebec 441 monitor_unblocked, mon);
293d2a00 442 }
7e2515e8
FB
443 }
444}
445
6cff3e85
PB
446void monitor_flush(Monitor *mon)
447{
dc7cbcd8 448 qemu_mutex_lock(&mon->mon_lock);
6cff3e85 449 monitor_flush_locked(mon);
dc7cbcd8 450 qemu_mutex_unlock(&mon->mon_lock);
6cff3e85
PB
451}
452
e1f2641b 453/* flush at every end of line */
376253ec 454static void monitor_puts(Monitor *mon, const char *str)
7e2515e8 455{
60fe76f3 456 char c;
731b0364 457
dc7cbcd8 458 qemu_mutex_lock(&mon->mon_lock);
7e2515e8
FB
459 for(;;) {
460 c = *str++;
461 if (c == '\0')
462 break;
e1f2641b
LC
463 if (c == '\n') {
464 qstring_append_chr(mon->outbuf, '\r');
465 }
466 qstring_append_chr(mon->outbuf, c);
467 if (c == '\n') {
6cff3e85 468 monitor_flush_locked(mon);
e1f2641b 469 }
7e2515e8 470 }
dc7cbcd8 471 qemu_mutex_unlock(&mon->mon_lock);
7e2515e8
FB
472}
473
376253ec 474void monitor_vprintf(Monitor *mon, const char *fmt, va_list ap)
9dc39cba 475{
e1f2641b 476 char *buf;
b8b08266 477
2daa1191
LC
478 if (!mon)
479 return;
480
9f3982f2 481 if (monitor_is_qmp(mon)) {
b8b08266 482 return;
4a29a85d 483 }
b8b08266 484
e1f2641b 485 buf = g_strdup_vprintf(fmt, ap);
b8b08266 486 monitor_puts(mon, buf);
e1f2641b 487 g_free(buf);
9dc39cba
FB
488}
489
376253ec 490void monitor_printf(Monitor *mon, const char *fmt, ...)
9dc39cba 491{
7e2515e8
FB
492 va_list ap;
493 va_start(ap, fmt);
376253ec 494 monitor_vprintf(mon, fmt, ap);
7e2515e8 495 va_end(ap);
9dc39cba
FB
496}
497
caf15319 498int monitor_fprintf(FILE *stream, const char *fmt, ...)
7fe48483
FB
499{
500 va_list ap;
501 va_start(ap, fmt);
376253ec 502 monitor_vprintf((Monitor *)stream, fmt, ap);
7fe48483
FB
503 va_end(ap);
504 return 0;
505}
506
65e3fe67 507static void qmp_send_response(Monitor *mon, QDict *rsp)
9b57c02e 508{
65e3fe67 509 QObject *data = QOBJECT(rsp);
9b57c02e
LC
510 QString *json;
511
83a27d4d
LC
512 json = mon->flags & MONITOR_USE_PRETTY ? qobject_to_json_pretty(data) :
513 qobject_to_json(data);
9b57c02e
LC
514 assert(json != NULL);
515
b8b08266
LC
516 qstring_append_chr(json, '\n');
517 monitor_puts(mon, qstring_get_str(json));
4a29a85d 518
cb3e7f08 519 qobject_unref(json);
9b57c02e
LC
520}
521
65e3fe67 522static void qmp_queue_response(Monitor *mon, QDict *rsp)
abe3cd0f 523{
f91dc2a0 524 if (mon->use_io_thread) {
abe3cd0f 525 /*
774a6b67
MA
526 * Push a reference to the response queue. The I/O thread
527 * drains that queue and emits.
abe3cd0f 528 */
abe3cd0f 529 qemu_mutex_lock(&mon->qmp.qmp_queue_lock);
65e3fe67 530 g_queue_push_tail(mon->qmp.qmp_responses, qobject_ref(rsp));
abe3cd0f 531 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
cab5ad86 532 qemu_bh_schedule(qmp_respond_bh);
abe3cd0f
PX
533 } else {
534 /*
774a6b67
MA
535 * Not using monitor I/O thread, i.e. we are in the main thread.
536 * Emit right away.
abe3cd0f 537 */
65e3fe67 538 qmp_send_response(mon, rsp);
abe3cd0f
PX
539 }
540}
541
542struct QMPResponse {
543 Monitor *mon;
d43b1694 544 QDict *data;
abe3cd0f
PX
545};
546typedef struct QMPResponse QMPResponse;
547
d43b1694 548static QDict *monitor_qmp_response_pop_one(Monitor *mon)
c73a843b 549{
d43b1694 550 QDict *data;
c73a843b
PX
551
552 qemu_mutex_lock(&mon->qmp.qmp_queue_lock);
553 data = g_queue_pop_head(mon->qmp.qmp_responses);
554 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
555
556 return data;
557}
558
559static void monitor_qmp_response_flush(Monitor *mon)
560{
d43b1694 561 QDict *data;
c73a843b
PX
562
563 while ((data = monitor_qmp_response_pop_one(mon))) {
65e3fe67 564 qmp_send_response(mon, data);
c73a843b
PX
565 qobject_unref(data);
566 }
567}
568
abe3cd0f 569/*
40687eb7
PX
570 * Pop a QMPResponse from any monitor's response queue into @response.
571 * Return false if all the queues are empty; else true.
abe3cd0f 572 */
40687eb7 573static bool monitor_qmp_response_pop_any(QMPResponse *response)
abe3cd0f
PX
574{
575 Monitor *mon;
d43b1694 576 QDict *data = NULL;
abe3cd0f
PX
577
578 qemu_mutex_lock(&monitor_lock);
579 QTAILQ_FOREACH(mon, &mon_list, entry) {
c73a843b 580 data = monitor_qmp_response_pop_one(mon);
abe3cd0f 581 if (data) {
40687eb7
PX
582 response->mon = mon;
583 response->data = data;
abe3cd0f
PX
584 break;
585 }
586 }
587 qemu_mutex_unlock(&monitor_lock);
40687eb7 588 return data != NULL;
abe3cd0f
PX
589}
590
591static void monitor_qmp_bh_responder(void *opaque)
592{
593 QMPResponse response;
594
40687eb7 595 while (monitor_qmp_response_pop_any(&response)) {
65e3fe67 596 qmp_send_response(response.mon, response.data);
cb3e7f08 597 qobject_unref(response.data);
abe3cd0f
PX
598 }
599}
600
7fb1cf16 601static MonitorQAPIEventConf monitor_qapi_event_conf[QAPI_EVENT__MAX] = {
b9b03ab0
MA
602 /* Limit guest-triggerable events to 1 per second */
603 [QAPI_EVENT_RTC_CHANGE] = { 1000 * SCALE_MS },
604 [QAPI_EVENT_WATCHDOG] = { 1000 * SCALE_MS },
605 [QAPI_EVENT_BALLOON_CHANGE] = { 1000 * SCALE_MS },
606 [QAPI_EVENT_QUORUM_REPORT_BAD] = { 1000 * SCALE_MS },
607 [QAPI_EVENT_QUORUM_FAILURE] = { 1000 * SCALE_MS },
608 [QAPI_EVENT_VSERPORT_CHANGE] = { 1000 * SCALE_MS },
609};
610
afeecec2 611/*
774a6b67
MA
612 * Broadcast an event to all monitors.
613 * @qdict is the event object. Its member "event" must match @event.
614 * Caller must hold monitor_lock.
afeecec2 615 */
688b4b7d 616static void monitor_qapi_event_emit(QAPIEvent event, QDict *qdict)
afeecec2
DB
617{
618 Monitor *mon;
619
688b4b7d 620 trace_monitor_protocol_event_emit(event, qdict);
238d9f34 621 QTAILQ_FOREACH(mon, &mon_list, entry) {
635db18f
MA
622 if (monitor_is_qmp(mon)
623 && mon->qmp.commands != &qmp_cap_negotiation_commands) {
65e3fe67 624 qmp_queue_response(mon, qdict);
afeecec2
DB
625 }
626 }
627}
628
a24712af
MA
629static void monitor_qapi_event_handler(void *opaque);
630
afeecec2
DB
631/*
632 * Queue a new event for emission to Monitor instances,
633 * applying any rate limiting if required.
634 */
635static void
9a105406 636monitor_qapi_event_queue_no_reenter(QAPIEvent event, QDict *qdict)
afeecec2 637{
b9b03ab0 638 MonitorQAPIEventConf *evconf;
43a14cfc 639 MonitorQAPIEventState *evstate;
afeecec2 640
7fb1cf16 641 assert(event < QAPI_EVENT__MAX);
b9b03ab0 642 evconf = &monitor_qapi_event_conf[event];
b9b03ab0 643 trace_monitor_protocol_event_queue(event, qdict, evconf->rate);
afeecec2 644
d622cb58 645 qemu_mutex_lock(&monitor_lock);
93f8f982 646
b9b03ab0 647 if (!evconf->rate) {
93f8f982 648 /* Unthrottled event */
688b4b7d 649 monitor_qapi_event_emit(event, qdict);
afeecec2 650 } else {
7dc847eb 651 QDict *data = qobject_to(QDict, qdict_get(qdict, "data"));
7de0be65 652 MonitorQAPIEventState key = { .event = event, .data = data };
a24712af
MA
653
654 evstate = g_hash_table_lookup(monitor_qapi_event_state, &key);
655 assert(!evstate || timer_pending(evstate->timer));
656
657 if (evstate) {
93f8f982 658 /*
b9b03ab0 659 * Timer is pending for (at least) evconf->rate ns after
93f8f982
MA
660 * last send. Store event for sending when timer fires,
661 * replacing a prior stored event if any.
afeecec2 662 */
cb3e7f08 663 qobject_unref(evstate->qdict);
f5a74a5a 664 evstate->qdict = qobject_ref(qdict);
afeecec2 665 } else {
93f8f982 666 /*
b9b03ab0 667 * Last send was (at least) evconf->rate ns ago.
93f8f982 668 * Send immediately, and arm the timer to call
b9b03ab0 669 * monitor_qapi_event_handler() in evconf->rate ns. Any
93f8f982
MA
670 * events arriving before then will be delayed until then.
671 */
6e8c5f4d 672 int64_t now = qemu_clock_get_ns(monitor_get_event_clock());
93f8f982 673
688b4b7d 674 monitor_qapi_event_emit(event, qdict);
a24712af
MA
675
676 evstate = g_new(MonitorQAPIEventState, 1);
677 evstate->event = event;
f5a74a5a 678 evstate->data = qobject_ref(data);
a24712af 679 evstate->qdict = NULL;
6e8c5f4d 680 evstate->timer = timer_new_ns(monitor_get_event_clock(),
a24712af
MA
681 monitor_qapi_event_handler,
682 evstate);
683 g_hash_table_add(monitor_qapi_event_state, evstate);
b9b03ab0 684 timer_mod_ns(evstate->timer, now + evconf->rate);
afeecec2
DB
685 }
686 }
93f8f982 687
d622cb58 688 qemu_mutex_unlock(&monitor_lock);
afeecec2
DB
689}
690
9a105406
MAL
691static void
692monitor_qapi_event_queue(QAPIEvent event, QDict *qdict, Error **errp)
693{
694 /*
695 * monitor_qapi_event_queue_no_reenter() is not reentrant: it
696 * would deadlock on monitor_lock. Work around by queueing
697 * events in thread-local storage.
698 * TODO: remove this, make it re-enter safe.
699 */
700 typedef struct MonitorQapiEvent {
701 QAPIEvent event;
702 QDict *qdict;
703 QSIMPLEQ_ENTRY(MonitorQapiEvent) entry;
704 } MonitorQapiEvent;
705 static __thread QSIMPLEQ_HEAD(, MonitorQapiEvent) event_queue;
706 static __thread bool reentered;
707 MonitorQapiEvent *ev;
708
709 if (!reentered) {
710 QSIMPLEQ_INIT(&event_queue);
711 }
712
713 ev = g_new(MonitorQapiEvent, 1);
714 ev->qdict = qobject_ref(qdict);
715 ev->event = event;
716 QSIMPLEQ_INSERT_TAIL(&event_queue, ev, entry);
717 if (reentered) {
718 return;
719 }
720
721 reentered = true;
722
723 while ((ev = QSIMPLEQ_FIRST(&event_queue)) != NULL) {
724 QSIMPLEQ_REMOVE_HEAD(&event_queue, entry);
725 monitor_qapi_event_queue_no_reenter(ev->event, ev->qdict);
726 qobject_unref(ev->qdict);
727 g_free(ev);
728 }
729
730 reentered = false;
731}
732
afeecec2 733/*
b9b03ab0 734 * This function runs evconf->rate ns after sending a throttled
93f8f982
MA
735 * event.
736 * If another event has since been stored, send it.
afeecec2 737 */
43a14cfc 738static void monitor_qapi_event_handler(void *opaque)
afeecec2 739{
43a14cfc 740 MonitorQAPIEventState *evstate = opaque;
b9b03ab0 741 MonitorQAPIEventConf *evconf = &monitor_qapi_event_conf[evstate->event];
afeecec2 742
93f8f982 743 trace_monitor_protocol_event_handler(evstate->event, evstate->qdict);
d622cb58 744 qemu_mutex_lock(&monitor_lock);
93f8f982 745
688b4b7d 746 if (evstate->qdict) {
6e8c5f4d 747 int64_t now = qemu_clock_get_ns(monitor_get_event_clock());
93f8f982 748
688b4b7d 749 monitor_qapi_event_emit(evstate->event, evstate->qdict);
cb3e7f08 750 qobject_unref(evstate->qdict);
688b4b7d 751 evstate->qdict = NULL;
b9b03ab0 752 timer_mod_ns(evstate->timer, now + evconf->rate);
a24712af
MA
753 } else {
754 g_hash_table_remove(monitor_qapi_event_state, evstate);
cb3e7f08 755 qobject_unref(evstate->data);
a24712af
MA
756 timer_free(evstate->timer);
757 g_free(evstate);
afeecec2 758 }
93f8f982 759
d622cb58 760 qemu_mutex_unlock(&monitor_lock);
afeecec2
DB
761}
762
a24712af 763static unsigned int qapi_event_throttle_hash(const void *key)
afeecec2 764{
a24712af 765 const MonitorQAPIEventState *evstate = key;
7de0be65 766 unsigned int hash = evstate->event * 255;
afeecec2 767
7de0be65
MA
768 if (evstate->event == QAPI_EVENT_VSERPORT_CHANGE) {
769 hash += g_str_hash(qdict_get_str(evstate->data, "id"));
770 }
771
6d425eb9
AG
772 if (evstate->event == QAPI_EVENT_QUORUM_REPORT_BAD) {
773 hash += g_str_hash(qdict_get_str(evstate->data, "node-name"));
774 }
775
7de0be65 776 return hash;
a24712af 777}
0d1ea871 778
a24712af
MA
779static gboolean qapi_event_throttle_equal(const void *a, const void *b)
780{
781 const MonitorQAPIEventState *eva = a;
782 const MonitorQAPIEventState *evb = b;
783
7de0be65
MA
784 if (eva->event != evb->event) {
785 return FALSE;
786 }
787
788 if (eva->event == QAPI_EVENT_VSERPORT_CHANGE) {
789 return !strcmp(qdict_get_str(eva->data, "id"),
790 qdict_get_str(evb->data, "id"));
791 }
792
6d425eb9
AG
793 if (eva->event == QAPI_EVENT_QUORUM_REPORT_BAD) {
794 return !strcmp(qdict_get_str(eva->data, "node-name"),
795 qdict_get_str(evb->data, "node-name"));
796 }
797
7de0be65 798 return TRUE;
a24712af
MA
799}
800
801static void monitor_qapi_event_init(void)
802{
803 monitor_qapi_event_state = g_hash_table_new(qapi_event_throttle_hash,
804 qapi_event_throttle_equal);
43a14cfc 805 qmp_event_set_func_emit(monitor_qapi_event_queue);
0d1ea871
LC
806}
807
7ef6cf63 808static void handle_hmp_command(Monitor *mon, const char *cmdline);
0268d97c 809
a5ed3525 810static void monitor_data_init(Monitor *mon, bool skip_flush,
f91dc2a0 811 bool use_io_thread)
b01fe89e
WX
812{
813 memset(mon, 0, sizeof(Monitor));
dc7cbcd8 814 qemu_mutex_init(&mon->mon_lock);
71da4667 815 qemu_mutex_init(&mon->qmp.qmp_queue_lock);
b01fe89e 816 mon->outbuf = qstring_new();
7717239d
WX
817 /* Use *mon_cmds by default. */
818 mon->cmd_table = mon_cmds;
88a95d10 819 mon->skip_flush = skip_flush;
f91dc2a0 820 mon->use_io_thread = use_io_thread;
71da4667 821 mon->qmp.qmp_requests = g_queue_new();
abe3cd0f 822 mon->qmp.qmp_responses = g_queue_new();
b01fe89e
WX
823}
824
825static void monitor_data_destroy(Monitor *mon)
826{
751f8cfe 827 g_free(mon->mon_cpu_path);
1ce2610c 828 qemu_chr_fe_deinit(&mon->chr, false);
2ef45716
MAL
829 if (monitor_is_qmp(mon)) {
830 json_message_parser_destroy(&mon->qmp.parser);
831 }
e5dc1a6c 832 readline_free(mon->rs);
cb3e7f08 833 qobject_unref(mon->outbuf);
dc7cbcd8 834 qemu_mutex_destroy(&mon->mon_lock);
71da4667 835 qemu_mutex_destroy(&mon->qmp.qmp_queue_lock);
6d2d563f
PX
836 monitor_qmp_cleanup_req_queue_locked(mon);
837 monitor_qmp_cleanup_resp_queue_locked(mon);
71da4667 838 g_queue_free(mon->qmp.qmp_requests);
abe3cd0f 839 g_queue_free(mon->qmp.qmp_responses);
b01fe89e
WX
840}
841
d51a67b4
LC
842char *qmp_human_monitor_command(const char *command_line, bool has_cpu_index,
843 int64_t cpu_index, Error **errp)
0268d97c 844{
d51a67b4 845 char *output = NULL;
0268d97c 846 Monitor *old_mon, hmp;
0268d97c 847
a5ed3525 848 monitor_data_init(&hmp, true, false);
0268d97c
LC
849
850 old_mon = cur_mon;
851 cur_mon = &hmp;
852
d51a67b4
LC
853 if (has_cpu_index) {
854 int ret = monitor_set_cpu(cpu_index);
0268d97c
LC
855 if (ret < 0) {
856 cur_mon = old_mon;
c6bd8c70
MA
857 error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "cpu-index",
858 "a CPU number");
0268d97c
LC
859 goto out;
860 }
861 }
862
7ef6cf63 863 handle_hmp_command(&hmp, command_line);
0268d97c
LC
864 cur_mon = old_mon;
865
dc7cbcd8 866 qemu_mutex_lock(&hmp.mon_lock);
48c043d0
LC
867 if (qstring_get_length(hmp.outbuf) > 0) {
868 output = g_strdup(qstring_get_str(hmp.outbuf));
d51a67b4
LC
869 } else {
870 output = g_strdup("");
0268d97c 871 }
dc7cbcd8 872 qemu_mutex_unlock(&hmp.mon_lock);
0268d97c
LC
873
874out:
b01fe89e 875 monitor_data_destroy(&hmp);
d51a67b4 876 return output;
0268d97c
LC
877}
878
9dc39cba
FB
879static int compare_cmd(const char *name, const char *list)
880{
881 const char *p, *pstart;
882 int len;
883 len = strlen(name);
884 p = list;
885 for(;;) {
886 pstart = p;
5c99fa37 887 p = qemu_strchrnul(p, '|');
9dc39cba
FB
888 if ((p - pstart) == len && !memcmp(pstart, name, len))
889 return 1;
890 if (*p == '\0')
891 break;
892 p++;
893 }
894 return 0;
895}
896
f5438c05
WX
897static int get_str(char *buf, int buf_size, const char **pp)
898{
899 const char *p;
900 char *q;
901 int c;
902
903 q = buf;
904 p = *pp;
905 while (qemu_isspace(*p)) {
906 p++;
907 }
908 if (*p == '\0') {
909 fail:
910 *q = '\0';
911 *pp = p;
912 return -1;
913 }
914 if (*p == '\"') {
915 p++;
916 while (*p != '\0' && *p != '\"') {
917 if (*p == '\\') {
918 p++;
919 c = *p++;
920 switch (c) {
921 case 'n':
922 c = '\n';
923 break;
924 case 'r':
925 c = '\r';
926 break;
927 case '\\':
928 case '\'':
929 case '\"':
930 break;
931 default:
71baf787 932 printf("unsupported escape code: '\\%c'\n", c);
f5438c05
WX
933 goto fail;
934 }
935 if ((q - buf) < buf_size - 1) {
936 *q++ = c;
937 }
938 } else {
939 if ((q - buf) < buf_size - 1) {
940 *q++ = *p;
941 }
942 p++;
943 }
944 }
945 if (*p != '\"') {
71baf787 946 printf("unterminated string\n");
f5438c05
WX
947 goto fail;
948 }
949 p++;
950 } else {
951 while (*p != '\0' && !qemu_isspace(*p)) {
952 if ((q - buf) < buf_size - 1) {
953 *q++ = *p;
954 }
955 p++;
956 }
957 }
958 *q = '\0';
959 *pp = p;
960 return 0;
961}
962
963#define MAX_ARGS 16
964
dcc70cdf
WX
965static void free_cmdline_args(char **args, int nb_args)
966{
967 int i;
968
969 assert(nb_args <= MAX_ARGS);
970
971 for (i = 0; i < nb_args; i++) {
972 g_free(args[i]);
973 }
974
975}
976
977/*
978 * Parse the command line to get valid args.
979 * @cmdline: command line to be parsed.
980 * @pnb_args: location to store the number of args, must NOT be NULL.
981 * @args: location to store the args, which should be freed by caller, must
982 * NOT be NULL.
983 *
984 * Returns 0 on success, negative on failure.
985 *
986 * NOTE: this parser is an approximate form of the real command parser. Number
987 * of args have a limit of MAX_ARGS. If cmdline contains more, it will
988 * return with failure.
989 */
990static int parse_cmdline(const char *cmdline,
991 int *pnb_args, char **args)
f5438c05
WX
992{
993 const char *p;
994 int nb_args, ret;
995 char buf[1024];
996
997 p = cmdline;
998 nb_args = 0;
999 for (;;) {
1000 while (qemu_isspace(*p)) {
1001 p++;
1002 }
1003 if (*p == '\0') {
1004 break;
1005 }
1006 if (nb_args >= MAX_ARGS) {
dcc70cdf 1007 goto fail;
f5438c05
WX
1008 }
1009 ret = get_str(buf, sizeof(buf), &p);
f5438c05 1010 if (ret < 0) {
dcc70cdf 1011 goto fail;
f5438c05 1012 }
dcc70cdf
WX
1013 args[nb_args] = g_strdup(buf);
1014 nb_args++;
f5438c05
WX
1015 }
1016 *pnb_args = nb_args;
dcc70cdf
WX
1017 return 0;
1018
1019 fail:
1020 free_cmdline_args(args, nb_args);
1021 return -1;
f5438c05
WX
1022}
1023
c3120f71 1024/*
774a6b67 1025 * Can command @cmd be executed in preconfig state?
c3120f71
DDAG
1026 */
1027static bool cmd_can_preconfig(const mon_cmd_t *cmd)
1028{
1029 if (!cmd->flags) {
1030 return false;
1031 }
1032
1033 return strchr(cmd->flags, 'p');
1034}
1035
66855495
WX
1036static void help_cmd_dump_one(Monitor *mon,
1037 const mon_cmd_t *cmd,
1038 char **prefix_args,
1039 int prefix_args_nb)
1040{
1041 int i;
1042
31785f1b
DDAG
1043 if (runstate_check(RUN_STATE_PRECONFIG) && !cmd_can_preconfig(cmd)) {
1044 return;
1045 }
1046
66855495
WX
1047 for (i = 0; i < prefix_args_nb; i++) {
1048 monitor_printf(mon, "%s ", prefix_args[i]);
1049 }
1050 monitor_printf(mon, "%s %s -- %s\n", cmd->name, cmd->params, cmd->help);
1051}
1052
1053/* @args[@arg_index] is the valid command need to find in @cmds */
c227f099 1054static void help_cmd_dump(Monitor *mon, const mon_cmd_t *cmds,
66855495 1055 char **args, int nb_args, int arg_index)
9dc39cba 1056{
c227f099 1057 const mon_cmd_t *cmd;
9dc39cba 1058
66855495
WX
1059 /* No valid arg need to compare with, dump all in *cmds */
1060 if (arg_index >= nb_args) {
1061 for (cmd = cmds; cmd->name != NULL; cmd++) {
1062 help_cmd_dump_one(mon, cmd, args, arg_index);
1063 }
1064 return;
1065 }
1066
1067 /* Find one entry to dump */
1068 for (cmd = cmds; cmd->name != NULL; cmd++) {
31785f1b
DDAG
1069 if (compare_cmd(args[arg_index], cmd->name) &&
1070 ((!runstate_check(RUN_STATE_PRECONFIG) ||
1071 cmd_can_preconfig(cmd)))) {
66855495
WX
1072 if (cmd->sub_table) {
1073 /* continue with next arg */
1074 help_cmd_dump(mon, cmd->sub_table,
1075 args, nb_args, arg_index + 1);
1076 } else {
1077 help_cmd_dump_one(mon, cmd, args, arg_index);
1078 }
1079 break;
1080 }
9dc39cba
FB
1081 }
1082}
1083
376253ec 1084static void help_cmd(Monitor *mon, const char *name)
9dc39cba 1085{
66855495
WX
1086 char *args[MAX_ARGS];
1087 int nb_args = 0;
1088
1089 /* 1. parse user input */
1090 if (name) {
1091 /* special case for log, directly dump and return */
1092 if (!strcmp(name, "log")) {
38dad9e5 1093 const QEMULogItem *item;
376253ec
AL
1094 monitor_printf(mon, "Log items (comma separated):\n");
1095 monitor_printf(mon, "%-10s %s\n", "none", "remove all logs");
38dad9e5 1096 for (item = qemu_log_items; item->mask != 0; item++) {
376253ec 1097 monitor_printf(mon, "%-10s %s\n", item->name, item->help);
f193c797 1098 }
66855495
WX
1099 return;
1100 }
1101
1102 if (parse_cmdline(name, &nb_args, args) < 0) {
1103 return;
f193c797 1104 }
9dc39cba 1105 }
66855495
WX
1106
1107 /* 2. dump the contents according to parsed args */
1108 help_cmd_dump(mon, mon->cmd_table, args, nb_args, 0);
1109
1110 free_cmdline_args(args, nb_args);
9dc39cba
FB
1111}
1112
d54908a5 1113static void do_help_cmd(Monitor *mon, const QDict *qdict)
38183186 1114{
d54908a5 1115 help_cmd(mon, qdict_get_try_str(qdict, "name"));
38183186
LC
1116}
1117
3e5a50d6 1118static void hmp_trace_event(Monitor *mon, const QDict *qdict)
22890ab5
PS
1119{
1120 const char *tp_name = qdict_get_str(qdict, "name");
1121 bool new_state = qdict_get_bool(qdict, "option");
77e2b172
LV
1122 bool has_vcpu = qdict_haskey(qdict, "vcpu");
1123 int vcpu = qdict_get_try_int(qdict, "vcpu", 0);
14101d02 1124 Error *local_err = NULL;
f871d689 1125
77e2b172
LV
1126 if (vcpu < 0) {
1127 monitor_printf(mon, "argument vcpu must be positive");
1128 return;
1129 }
1130
1131 qmp_trace_event_set_state(tp_name, new_state, true, true, has_vcpu, vcpu, &local_err);
14101d02 1132 if (local_err) {
091e38b7 1133 error_report_err(local_err);
f871d689 1134 }
22890ab5 1135}
c5ceb523 1136
c45a8168 1137#ifdef CONFIG_TRACE_SIMPLE
3e5a50d6 1138static void hmp_trace_file(Monitor *mon, const QDict *qdict)
c5ceb523
SH
1139{
1140 const char *op = qdict_get_try_str(qdict, "op");
1141 const char *arg = qdict_get_try_str(qdict, "arg");
1142
1143 if (!op) {
1144 st_print_trace_file_status((FILE *)mon, &monitor_fprintf);
1145 } else if (!strcmp(op, "on")) {
1146 st_set_trace_file_enabled(true);
1147 } else if (!strcmp(op, "off")) {
1148 st_set_trace_file_enabled(false);
1149 } else if (!strcmp(op, "flush")) {
1150 st_flush_trace_buffer();
1151 } else if (!strcmp(op, "set")) {
1152 if (arg) {
1153 st_set_trace_file(arg);
1154 }
1155 } else {
1156 monitor_printf(mon, "unexpected argument \"%s\"\n", op);
1157 help_cmd(mon, "trace-file");
1158 }
1159}
22890ab5
PS
1160#endif
1161
3e5a50d6 1162static void hmp_info_help(Monitor *mon, const QDict *qdict)
9dc39cba 1163{
13c7425e 1164 help_cmd(mon, "info");
9dc39cba
FB
1165}
1166
9e812b6a 1167static void query_commands_cb(QmpCommand *cmd, void *opaque)
e3bba9d0 1168{
9e812b6a 1169 CommandInfoList *info, **list = opaque;
e3bba9d0 1170
9e812b6a
MAL
1171 if (!cmd->enabled) {
1172 return;
e3bba9d0
LC
1173 }
1174
9e812b6a
MAL
1175 info = g_malloc0(sizeof(*info));
1176 info->value = g_malloc0(sizeof(*info->value));
1177 info->value->name = g_strdup(cmd->name);
1178 info->next = *list;
1179 *list = info;
1180}
1181
1182CommandInfoList *qmp_query_commands(Error **errp)
1183{
1184 CommandInfoList *list = NULL;
1185
635db18f 1186 qmp_for_each_command(cur_mon->qmp.commands, query_commands_cb, &list);
9e812b6a
MAL
1187
1188 return list;
a36e69dd
TS
1189}
1190
4860853d
DB
1191EventInfoList *qmp_query_events(Error **errp)
1192{
1193 EventInfoList *info, *ev_list = NULL;
75175173 1194 QAPIEvent e;
4860853d 1195
7fb1cf16 1196 for (e = 0 ; e < QAPI_EVENT__MAX ; e++) {
977c736f 1197 const char *event_name = QAPIEvent_str(e);
4860853d
DB
1198 assert(event_name != NULL);
1199 info = g_malloc0(sizeof(*info));
1200 info->value = g_malloc0(sizeof(*info->value));
1201 info->value->name = g_strdup(event_name);
1202
1203 info->next = ev_list;
1204 ev_list = info;
1205 }
1206
1207 return ev_list;
1208}
1209
39a18158
MA
1210/*
1211 * Minor hack: generated marshalling suppressed for this command
1212 * ('gen': false in the schema) so we can parse the JSON string
1213 * directly into QObject instead of first parsing it with
1214 * visit_type_SchemaInfoList() into a SchemaInfoList, then marshal it
1215 * to QObject with generated output marshallers, every time. Instead,
b3db211f 1216 * we do it in test-qobject-input-visitor.c, just to make sure
fb0bc835 1217 * qapi-gen.py's output actually conforms to the schema.
39a18158
MA
1218 */
1219static void qmp_query_qmp_schema(QDict *qdict, QObject **ret_data,
1220 Error **errp)
1221{
7d0f982b 1222 *ret_data = qobject_from_qlit(&qmp_schema_qlit);
39a18158
MA
1223}
1224
5032a16d 1225/*
5032a16d
MAL
1226 * We used to define commands in qmp-commands.hx in addition to the
1227 * QAPI schema. This permitted defining some of them only in certain
1228 * configurations. query-commands has always reflected that (good,
1229 * because it lets QMP clients figure out what's actually available),
1230 * while query-qmp-schema never did (not so good). This function is a
1231 * hack to keep the configuration-specific commands defined exactly as
1232 * before, even though qmp-commands.hx is gone.
1233 *
1234 * FIXME Educate the QAPI schema on configuration-specific commands,
1235 * and drop this hack.
1236 */
1237static void qmp_unregister_commands_hack(void)
1238{
38bb54f3
MA
1239#ifndef CONFIG_REPLICATION
1240 qmp_unregister_command(&qmp_commands, "xen-set-replication");
1241 qmp_unregister_command(&qmp_commands, "query-xen-replication-status");
1242 qmp_unregister_command(&qmp_commands, "xen-colo-do-checkpoint");
1243#endif
5032a16d 1244#ifndef TARGET_I386
1527badb 1245 qmp_unregister_command(&qmp_commands, "rtc-reset-reinjection");
08a161fd 1246 qmp_unregister_command(&qmp_commands, "query-sev");
1b6a034f 1247 qmp_unregister_command(&qmp_commands, "query-sev-launch-measure");
31dd67f6 1248 qmp_unregister_command(&qmp_commands, "query-sev-capabilities");
5032a16d
MAL
1249#endif
1250#ifndef TARGET_S390X
1527badb 1251 qmp_unregister_command(&qmp_commands, "dump-skeys");
5032a16d
MAL
1252#endif
1253#ifndef TARGET_ARM
1527badb 1254 qmp_unregister_command(&qmp_commands, "query-gic-capabilities");
5032a16d 1255#endif
f99fd7ca 1256#if !defined(TARGET_S390X) && !defined(TARGET_I386)
1527badb 1257 qmp_unregister_command(&qmp_commands, "query-cpu-model-expansion");
f99fd7ca
EH
1258#endif
1259#if !defined(TARGET_S390X)
1527badb
MA
1260 qmp_unregister_command(&qmp_commands, "query-cpu-model-baseline");
1261 qmp_unregister_command(&qmp_commands, "query-cpu-model-comparison");
728b1429
EH
1262#endif
1263#if !defined(TARGET_PPC) && !defined(TARGET_ARM) && !defined(TARGET_I386) \
1264 && !defined(TARGET_S390X)
1527badb 1265 qmp_unregister_command(&qmp_commands, "query-cpu-definitions");
728b1429 1266#endif
5032a16d
MAL
1267}
1268
6adf08dd 1269static void monitor_init_qmp_commands(void)
edcfaefe 1270{
635db18f
MA
1271 /*
1272 * Two command lists:
1273 * - qmp_commands contains all QMP commands
1274 * - qmp_cap_negotiation_commands contains just
1275 * "qmp_capabilities", to enforce capability negotiation
1276 */
1277
1527badb 1278 qmp_init_marshal(&qmp_commands);
05875687 1279
1527badb 1280 qmp_register_command(&qmp_commands, "query-qmp-schema",
d6fe3d02 1281 qmp_query_qmp_schema, QCO_ALLOW_PRECONFIG);
1527badb 1282 qmp_register_command(&qmp_commands, "device_add", qmp_device_add,
edcfaefe 1283 QCO_NO_OPTIONS);
1527badb 1284 qmp_register_command(&qmp_commands, "netdev_add", qmp_netdev_add,
edcfaefe 1285 QCO_NO_OPTIONS);
5032a16d 1286
05875687 1287 qmp_unregister_commands_hack();
635db18f
MA
1288
1289 QTAILQ_INIT(&qmp_cap_negotiation_commands);
1290 qmp_register_command(&qmp_cap_negotiation_commands, "qmp_capabilities",
d6fe3d02 1291 qmp_marshal_qmp_capabilities, QCO_ALLOW_PRECONFIG);
635db18f
MA
1292}
1293
71da4667
PX
1294static bool qmp_oob_enabled(Monitor *mon)
1295{
279f9e08 1296 return mon->qmp.capab[QMP_CAPABILITY_OOB];
02130314
PX
1297}
1298
279f9e08 1299static void monitor_qmp_caps_reset(Monitor *mon)
635db18f 1300{
279f9e08
MA
1301 memset(mon->qmp.capab_offered, 0, sizeof(mon->qmp.capab_offered));
1302 memset(mon->qmp.capab, 0, sizeof(mon->qmp.capab));
1303 mon->qmp.capab_offered[QMP_CAPABILITY_OOB] = mon->use_io_thread;
02130314
PX
1304}
1305
cf869d53 1306/*
279f9e08
MA
1307 * Accept QMP capabilities in @list for @mon.
1308 * On success, set mon->qmp.capab[], and return true.
1309 * On error, set @errp, and return false.
cf869d53 1310 */
279f9e08
MA
1311static bool qmp_caps_accept(Monitor *mon, QMPCapabilityList *list,
1312 Error **errp)
cf869d53 1313{
279f9e08
MA
1314 GString *unavailable = NULL;
1315 bool capab[QMP_CAPABILITY__MAX];
cf869d53 1316
279f9e08 1317 memset(capab, 0, sizeof(capab));
cf869d53 1318
02130314 1319 for (; list; list = list->next) {
279f9e08
MA
1320 if (!mon->qmp.capab_offered[list->value]) {
1321 if (!unavailable) {
1322 unavailable = g_string_new(QMPCapability_str(list->value));
1323 } else {
1324 g_string_append_printf(unavailable, ", %s",
1325 QMPCapability_str(list->value));
02130314 1326 }
9ddb7456 1327 }
279f9e08 1328 capab[list->value] = true;
cf869d53
PX
1329 }
1330
279f9e08
MA
1331 if (unavailable) {
1332 error_setg(errp, "Capability %s not available", unavailable->str);
1333 g_string_free(unavailable, true);
1334 return false;
cf869d53
PX
1335 }
1336
279f9e08 1337 memcpy(mon->qmp.capab, capab, sizeof(capab));
cf869d53
PX
1338 return true;
1339}
1340
02130314
PX
1341void qmp_qmp_capabilities(bool has_enable, QMPCapabilityList *enable,
1342 Error **errp)
1343{
635db18f
MA
1344 if (cur_mon->qmp.commands == &qmp_commands) {
1345 error_set(errp, ERROR_CLASS_COMMAND_NOT_FOUND,
1346 "Capabilities negotiation is already complete, command "
1347 "ignored");
1348 return;
1349 }
1350
279f9e08
MA
1351 if (!qmp_caps_accept(cur_mon, enable, errp)) {
1352 return;
02130314
PX
1353 }
1354
635db18f 1355 cur_mon->qmp.commands = &qmp_commands;
edcfaefe
MAL
1356}
1357
d9f25280 1358/* Set the current CPU defined by the user. Callers must hold BQL. */
b025c8b4 1359int monitor_set_cpu(int cpu_index)
6a00d601 1360{
55e5c285 1361 CPUState *cpu;
6a00d601 1362
1c8bb3cc
AF
1363 cpu = qemu_get_cpu(cpu_index);
1364 if (cpu == NULL) {
1365 return -1;
6a00d601 1366 }
751f8cfe
GK
1367 g_free(cur_mon->mon_cpu_path);
1368 cur_mon->mon_cpu_path = object_get_canonical_path(OBJECT(cpu));
1c8bb3cc 1369 return 0;
6a00d601
FB
1370}
1371
d9f25280 1372/* Callers must hold BQL. */
137b5cb6 1373static CPUState *mon_get_cpu_sync(bool synchronize)
6a00d601 1374{
751f8cfe
GK
1375 CPUState *cpu;
1376
1377 if (cur_mon->mon_cpu_path) {
1378 cpu = (CPUState *) object_resolve_path_type(cur_mon->mon_cpu_path,
1379 TYPE_CPU, NULL);
1380 if (!cpu) {
1381 g_free(cur_mon->mon_cpu_path);
1382 cur_mon->mon_cpu_path = NULL;
1383 }
1384 }
1385 if (!cur_mon->mon_cpu_path) {
854e67fe
TH
1386 if (!first_cpu) {
1387 return NULL;
1388 }
27a83f8e 1389 monitor_set_cpu(first_cpu->cpu_index);
751f8cfe 1390 cpu = first_cpu;
6a00d601 1391 }
137b5cb6
VM
1392 if (synchronize) {
1393 cpu_synchronize_state(cpu);
1394 }
751f8cfe 1395 return cpu;
5bcda5f7
PC
1396}
1397
137b5cb6
VM
1398CPUState *mon_get_cpu(void)
1399{
1400 return mon_get_cpu_sync(true);
1401}
1402
bf957284 1403CPUArchState *mon_get_cpu_env(void)
5bcda5f7 1404{
854e67fe
TH
1405 CPUState *cs = mon_get_cpu();
1406
1407 return cs ? cs->env_ptr : NULL;
6a00d601
FB
1408}
1409
99b7796f
LC
1410int monitor_get_cpu_index(void)
1411{
137b5cb6 1412 CPUState *cs = mon_get_cpu_sync(false);
854e67fe
TH
1413
1414 return cs ? cs->cpu_index : UNASSIGNED_CPU_INDEX;
99b7796f
LC
1415}
1416
1ce6be24 1417static void hmp_info_registers(Monitor *mon, const QDict *qdict)
9307c4c1 1418{
18f08282
SJS
1419 bool all_cpus = qdict_get_try_bool(qdict, "cpustate_all", false);
1420 CPUState *cs;
854e67fe 1421
18f08282
SJS
1422 if (all_cpus) {
1423 CPU_FOREACH(cs) {
1424 monitor_printf(mon, "\nCPU#%d\n", cs->cpu_index);
1425 cpu_dump_state(cs, (FILE *)mon, monitor_fprintf, CPU_DUMP_FPU);
1426 }
1427 } else {
1428 cs = mon_get_cpu();
1429
1430 if (!cs) {
1431 monitor_printf(mon, "No CPU available\n");
1432 return;
1433 }
1434
1435 cpu_dump_state(cs, (FILE *)mon, monitor_fprintf, CPU_DUMP_FPU);
854e67fe 1436 }
9307c4c1
FB
1437}
1438
f0d14a95 1439#ifdef CONFIG_TCG
1ce6be24 1440static void hmp_info_jit(Monitor *mon, const QDict *qdict)
e3db7226 1441{
b7da97ee
TH
1442 if (!tcg_enabled()) {
1443 error_report("JIT information is only available with accel=tcg");
1444 return;
1445 }
1446
376253ec 1447 dump_exec_info((FILE *)mon, monitor_fprintf);
27498bef 1448 dump_drift_info((FILE *)mon, monitor_fprintf);
e3db7226
FB
1449}
1450
1ce6be24 1451static void hmp_info_opcount(Monitor *mon, const QDict *qdict)
246ae24d
MF
1452{
1453 dump_opcount_info((FILE *)mon, monitor_fprintf);
1454}
f0d14a95 1455#endif
246ae24d 1456
1ce6be24 1457static void hmp_info_history(Monitor *mon, const QDict *qdict)
aa455485
FB
1458{
1459 int i;
7e2515e8 1460 const char *str;
3b46e624 1461
cde76ee1
AL
1462 if (!mon->rs)
1463 return;
7e2515e8
FB
1464 i = 0;
1465 for(;;) {
731b0364 1466 str = readline_get_history(mon->rs, i);
7e2515e8
FB
1467 if (!str)
1468 break;
376253ec 1469 monitor_printf(mon, "%d: '%s'\n", i, str);
8e3a9fd2 1470 i++;
aa455485
FB
1471 }
1472}
1473
1ce6be24 1474static void hmp_info_cpustats(Monitor *mon, const QDict *qdict)
76a66253 1475{
854e67fe
TH
1476 CPUState *cs = mon_get_cpu();
1477
1478 if (!cs) {
1479 monitor_printf(mon, "No CPU available\n");
1480 return;
1481 }
1482 cpu_dump_statistics(cs, (FILE *)mon, &monitor_fprintf, 0);
76a66253 1483}
76a66253 1484
1ce6be24 1485static void hmp_info_trace_events(Monitor *mon, const QDict *qdict)
22890ab5 1486{
bd71211d 1487 const char *name = qdict_get_try_str(qdict, "name");
77e2b172
LV
1488 bool has_vcpu = qdict_haskey(qdict, "vcpu");
1489 int vcpu = qdict_get_try_int(qdict, "vcpu", 0);
bd71211d 1490 TraceEventInfoList *events;
14101d02 1491 TraceEventInfoList *elem;
bd71211d
LV
1492 Error *local_err = NULL;
1493
1494 if (name == NULL) {
1495 name = "*";
1496 }
77e2b172
LV
1497 if (vcpu < 0) {
1498 monitor_printf(mon, "argument vcpu must be positive");
1499 return;
1500 }
bd71211d 1501
77e2b172 1502 events = qmp_trace_event_get_state(name, has_vcpu, vcpu, &local_err);
bd71211d
LV
1503 if (local_err) {
1504 error_report_err(local_err);
1505 return;
1506 }
14101d02
LV
1507
1508 for (elem = events; elem != NULL; elem = elem->next) {
1509 monitor_printf(mon, "%s : state %u\n",
1510 elem->value->name,
1511 elem->value->state == TRACE_EVENT_STATE_ENABLED ? 1 : 0);
1512 }
1513 qapi_free_TraceEventInfoList(events);
22890ab5 1514}
22890ab5 1515
b8a185bc
MA
1516void qmp_client_migrate_info(const char *protocol, const char *hostname,
1517 bool has_port, int64_t port,
1518 bool has_tls_port, int64_t tls_port,
1519 bool has_cert_subject, const char *cert_subject,
1520 Error **errp)
e866e239 1521{
e866e239 1522 if (strcmp(protocol, "spice") == 0) {
b8a185bc
MA
1523 if (!qemu_using_spice(errp)) {
1524 return;
e866e239
GH
1525 }
1526
b8a185bc 1527 if (!has_port && !has_tls_port) {
c6bd8c70 1528 error_setg(errp, QERR_MISSING_PARAMETER, "port/tls-port");
b8a185bc 1529 return;
6ec5dae5
YH
1530 }
1531
b8a185bc
MA
1532 if (qemu_spice_migrate_info(hostname,
1533 has_port ? port : -1,
1534 has_tls_port ? tls_port : -1,
1535 cert_subject)) {
c6bd8c70 1536 error_setg(errp, QERR_UNDEFINED_ERROR);
b8a185bc 1537 return;
e866e239 1538 }
b8a185bc 1539 return;
e866e239
GH
1540 }
1541
c6bd8c70 1542 error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "protocol", "spice");
e866e239
GH
1543}
1544
3e5a50d6 1545static void hmp_logfile(Monitor *mon, const QDict *qdict)
e735b91c 1546{
daa76aa4
MA
1547 Error *err = NULL;
1548
1549 qemu_set_log_filename(qdict_get_str(qdict, "filename"), &err);
1550 if (err) {
1551 error_report_err(err);
1552 }
e735b91c
PB
1553}
1554
3e5a50d6 1555static void hmp_log(Monitor *mon, const QDict *qdict)
f193c797
FB
1556{
1557 int mask;
d54908a5 1558 const char *items = qdict_get_str(qdict, "items");
3b46e624 1559
9307c4c1 1560 if (!strcmp(items, "none")) {
f193c797
FB
1561 mask = 0;
1562 } else {
4fde1eba 1563 mask = qemu_str_to_log_mask(items);
f193c797 1564 if (!mask) {
376253ec 1565 help_cmd(mon, "log");
f193c797
FB
1566 return;
1567 }
1568 }
24537a01 1569 qemu_set_log(mask);
f193c797
FB
1570}
1571
3e5a50d6 1572static void hmp_singlestep(Monitor *mon, const QDict *qdict)
1b530a6d 1573{
d54908a5 1574 const char *option = qdict_get_try_str(qdict, "option");
1b530a6d
AJ
1575 if (!option || !strcmp(option, "on")) {
1576 singlestep = 1;
1577 } else if (!strcmp(option, "off")) {
1578 singlestep = 0;
1579 } else {
1580 monitor_printf(mon, "unexpected option %s\n", option);
1581 }
1582}
1583
3e5a50d6 1584static void hmp_gdbserver(Monitor *mon, const QDict *qdict)
59030a8c 1585{
d54908a5 1586 const char *device = qdict_get_try_str(qdict, "device");
59030a8c
AL
1587 if (!device)
1588 device = "tcp::" DEFAULT_GDBSTUB_PORT;
1589 if (gdbserver_start(device) < 0) {
1590 monitor_printf(mon, "Could not open gdbserver on device '%s'\n",
1591 device);
1592 } else if (strcmp(device, "none") == 0) {
36556b20 1593 monitor_printf(mon, "Disabled gdbserver\n");
8a7ddc38 1594 } else {
59030a8c
AL
1595 monitor_printf(mon, "Waiting for gdb connection on device '%s'\n",
1596 device);
8a7ddc38
FB
1597 }
1598}
1599
3e5a50d6 1600static void hmp_watchdog_action(Monitor *mon, const QDict *qdict)
9dd986cc 1601{
d54908a5 1602 const char *action = qdict_get_str(qdict, "action");
9dd986cc
RJ
1603 if (select_watchdog_action(action) == -1) {
1604 monitor_printf(mon, "Unknown watchdog action '%s'\n", action);
1605 }
1606}
1607
376253ec 1608static void monitor_printc(Monitor *mon, int c)
9307c4c1 1609{
376253ec 1610 monitor_printf(mon, "'");
9307c4c1
FB
1611 switch(c) {
1612 case '\'':
376253ec 1613 monitor_printf(mon, "\\'");
9307c4c1
FB
1614 break;
1615 case '\\':
376253ec 1616 monitor_printf(mon, "\\\\");
9307c4c1
FB
1617 break;
1618 case '\n':
376253ec 1619 monitor_printf(mon, "\\n");
9307c4c1
FB
1620 break;
1621 case '\r':
376253ec 1622 monitor_printf(mon, "\\r");
9307c4c1
FB
1623 break;
1624 default:
1625 if (c >= 32 && c <= 126) {
376253ec 1626 monitor_printf(mon, "%c", c);
9307c4c1 1627 } else {
376253ec 1628 monitor_printf(mon, "\\x%02x", c);
9307c4c1
FB
1629 }
1630 break;
1631 }
376253ec 1632 monitor_printf(mon, "'");
9307c4c1
FB
1633}
1634
376253ec 1635static void memory_dump(Monitor *mon, int count, int format, int wsize,
a8170e5e 1636 hwaddr addr, int is_physical)
9307c4c1 1637{
23842aab 1638 int l, line_size, i, max_digits, len;
9307c4c1
FB
1639 uint8_t buf[16];
1640 uint64_t v;
854e67fe
TH
1641 CPUState *cs = mon_get_cpu();
1642
1643 if (!cs && (format == 'i' || !is_physical)) {
1644 monitor_printf(mon, "Can not dump without CPU\n");
1645 return;
1646 }
9307c4c1
FB
1647
1648 if (format == 'i') {
1d48474d 1649 monitor_disas(mon, cs, addr, count, is_physical);
9307c4c1
FB
1650 return;
1651 }
1652
1653 len = wsize * count;
1654 if (wsize == 1)
1655 line_size = 8;
1656 else
1657 line_size = 16;
9307c4c1
FB
1658 max_digits = 0;
1659
1660 switch(format) {
1661 case 'o':
69db8dfc 1662 max_digits = DIV_ROUND_UP(wsize * 8, 3);
9307c4c1
FB
1663 break;
1664 default:
1665 case 'x':
1666 max_digits = (wsize * 8) / 4;
1667 break;
1668 case 'u':
1669 case 'd':
69db8dfc 1670 max_digits = DIV_ROUND_UP(wsize * 8 * 10, 33);
9307c4c1
FB
1671 break;
1672 case 'c':
1673 wsize = 1;
1674 break;
1675 }
1676
1677 while (len > 0) {
7743e588 1678 if (is_physical)
376253ec 1679 monitor_printf(mon, TARGET_FMT_plx ":", addr);
7743e588 1680 else
376253ec 1681 monitor_printf(mon, TARGET_FMT_lx ":", (target_ulong)addr);
9307c4c1
FB
1682 l = len;
1683 if (l > line_size)
1684 l = line_size;
1685 if (is_physical) {
54f7b4a3 1686 cpu_physical_memory_read(addr, buf, l);
9307c4c1 1687 } else {
854e67fe 1688 if (cpu_memory_rw_debug(cs, addr, buf, l, 0) < 0) {
376253ec 1689 monitor_printf(mon, " Cannot access memory\n");
c8f79b67
AL
1690 break;
1691 }
9307c4c1 1692 }
5fafdf24 1693 i = 0;
9307c4c1
FB
1694 while (i < l) {
1695 switch(wsize) {
1696 default:
1697 case 1:
24e60305 1698 v = ldub_p(buf + i);
9307c4c1
FB
1699 break;
1700 case 2:
24e60305 1701 v = lduw_p(buf + i);
9307c4c1
FB
1702 break;
1703 case 4:
24e60305 1704 v = (uint32_t)ldl_p(buf + i);
9307c4c1
FB
1705 break;
1706 case 8:
24e60305 1707 v = ldq_p(buf + i);
9307c4c1
FB
1708 break;
1709 }
376253ec 1710 monitor_printf(mon, " ");
9307c4c1
FB
1711 switch(format) {
1712 case 'o':
376253ec 1713 monitor_printf(mon, "%#*" PRIo64, max_digits, v);
9307c4c1
FB
1714 break;
1715 case 'x':
376253ec 1716 monitor_printf(mon, "0x%0*" PRIx64, max_digits, v);
9307c4c1
FB
1717 break;
1718 case 'u':
376253ec 1719 monitor_printf(mon, "%*" PRIu64, max_digits, v);
9307c4c1
FB
1720 break;
1721 case 'd':
376253ec 1722 monitor_printf(mon, "%*" PRId64, max_digits, v);
9307c4c1
FB
1723 break;
1724 case 'c':
376253ec 1725 monitor_printc(mon, v);
9307c4c1
FB
1726 break;
1727 }
1728 i += wsize;
1729 }
376253ec 1730 monitor_printf(mon, "\n");
9307c4c1
FB
1731 addr += l;
1732 len -= l;
1733 }
1734}
1735
3e5a50d6 1736static void hmp_memory_dump(Monitor *mon, const QDict *qdict)
9307c4c1 1737{
1bd1442e
LC
1738 int count = qdict_get_int(qdict, "count");
1739 int format = qdict_get_int(qdict, "format");
1740 int size = qdict_get_int(qdict, "size");
1741 target_long addr = qdict_get_int(qdict, "addr");
1742
376253ec 1743 memory_dump(mon, count, format, size, addr, 0);
9307c4c1
FB
1744}
1745
3e5a50d6 1746static void hmp_physical_memory_dump(Monitor *mon, const QDict *qdict)
9307c4c1 1747{
1bd1442e
LC
1748 int count = qdict_get_int(qdict, "count");
1749 int format = qdict_get_int(qdict, "format");
1750 int size = qdict_get_int(qdict, "size");
a8170e5e 1751 hwaddr addr = qdict_get_int(qdict, "addr");
1bd1442e 1752
376253ec 1753 memory_dump(mon, count, format, size, addr, 1);
9307c4c1
FB
1754}
1755
e9628441
PB
1756static void *gpa2hva(MemoryRegion **p_mr, hwaddr addr, Error **errp)
1757{
1758 MemoryRegionSection mrs = memory_region_find(get_system_memory(),
1759 addr, 1);
1760
1761 if (!mrs.mr) {
1762 error_setg(errp, "No memory is mapped at address 0x%" HWADDR_PRIx, addr);
1763 return NULL;
1764 }
1765
1766 if (!memory_region_is_ram(mrs.mr) && !memory_region_is_romd(mrs.mr)) {
1767 error_setg(errp, "Memory at address 0x%" HWADDR_PRIx "is not RAM", addr);
1768 memory_region_unref(mrs.mr);
1769 return NULL;
1770 }
1771
1772 *p_mr = mrs.mr;
1773 return qemu_map_ram_ptr(mrs.mr->ram_block, mrs.offset_within_region);
1774}
1775
1776static void hmp_gpa2hva(Monitor *mon, const QDict *qdict)
1777{
1778 hwaddr addr = qdict_get_int(qdict, "addr");
1779 Error *local_err = NULL;
1780 MemoryRegion *mr = NULL;
1781 void *ptr;
1782
1783 ptr = gpa2hva(&mr, addr, &local_err);
1784 if (local_err) {
1785 error_report_err(local_err);
1786 return;
1787 }
1788
1789 monitor_printf(mon, "Host virtual address for 0x%" HWADDR_PRIx
1790 " (%s) is %p\n",
1791 addr, mr->name, ptr);
1792
1793 memory_region_unref(mr);
1794}
1795
1796#ifdef CONFIG_LINUX
1797static uint64_t vtop(void *ptr, Error **errp)
1798{
1799 uint64_t pinfo;
1800 uint64_t ret = -1;
1801 uintptr_t addr = (uintptr_t) ptr;
1802 uintptr_t pagesize = getpagesize();
1803 off_t offset = addr / pagesize * sizeof(pinfo);
1804 int fd;
1805
1806 fd = open("/proc/self/pagemap", O_RDONLY);
1807 if (fd == -1) {
1808 error_setg_errno(errp, errno, "Cannot open /proc/self/pagemap");
1809 return -1;
1810 }
1811
1812 /* Force copy-on-write if necessary. */
1813 atomic_add((uint8_t *)ptr, 0);
1814
1815 if (pread(fd, &pinfo, sizeof(pinfo), offset) != sizeof(pinfo)) {
1816 error_setg_errno(errp, errno, "Cannot read pagemap");
1817 goto out;
1818 }
1819 if ((pinfo & (1ull << 63)) == 0) {
1820 error_setg(errp, "Page not present");
1821 goto out;
1822 }
1823 ret = ((pinfo & 0x007fffffffffffffull) * pagesize) | (addr & (pagesize - 1));
1824
1825out:
1826 close(fd);
1827 return ret;
1828}
1829
1830static void hmp_gpa2hpa(Monitor *mon, const QDict *qdict)
1831{
1832 hwaddr addr = qdict_get_int(qdict, "addr");
1833 Error *local_err = NULL;
1834 MemoryRegion *mr = NULL;
1835 void *ptr;
1836 uint64_t physaddr;
1837
1838 ptr = gpa2hva(&mr, addr, &local_err);
1839 if (local_err) {
1840 error_report_err(local_err);
1841 return;
1842 }
1843
1844 physaddr = vtop(ptr, &local_err);
1845 if (local_err) {
1846 error_report_err(local_err);
1847 } else {
1848 monitor_printf(mon, "Host physical address for 0x%" HWADDR_PRIx
1849 " (%s) is 0x%" PRIx64 "\n",
1850 addr, mr->name, (uint64_t) physaddr);
1851 }
1852
1853 memory_region_unref(mr);
1854}
1855#endif
1856
1bd1442e 1857static void do_print(Monitor *mon, const QDict *qdict)
9307c4c1 1858{
1bd1442e 1859 int format = qdict_get_int(qdict, "format");
a8170e5e 1860 hwaddr val = qdict_get_int(qdict, "val");
1bd1442e 1861
9307c4c1
FB
1862 switch(format) {
1863 case 'o':
a8170e5e 1864 monitor_printf(mon, "%#" HWADDR_PRIo, val);
9307c4c1
FB
1865 break;
1866 case 'x':
a8170e5e 1867 monitor_printf(mon, "%#" HWADDR_PRIx, val);
9307c4c1
FB
1868 break;
1869 case 'u':
a8170e5e 1870 monitor_printf(mon, "%" HWADDR_PRIu, val);
9307c4c1
FB
1871 break;
1872 default:
1873 case 'd':
a8170e5e 1874 monitor_printf(mon, "%" HWADDR_PRId, val);
9307c4c1
FB
1875 break;
1876 case 'c':
376253ec 1877 monitor_printc(mon, val);
9307c4c1
FB
1878 break;
1879 }
376253ec 1880 monitor_printf(mon, "\n");
9307c4c1
FB
1881}
1882
3e5a50d6 1883static void hmp_sum(Monitor *mon, const QDict *qdict)
e4cf1adc
FB
1884{
1885 uint32_t addr;
e4cf1adc 1886 uint16_t sum;
f18c16de
LC
1887 uint32_t start = qdict_get_int(qdict, "start");
1888 uint32_t size = qdict_get_int(qdict, "size");
e4cf1adc
FB
1889
1890 sum = 0;
1891 for(addr = start; addr < (start + size); addr++) {
42874d3a
PM
1892 uint8_t val = address_space_ldub(&address_space_memory, addr,
1893 MEMTXATTRS_UNSPECIFIED, NULL);
e4cf1adc
FB
1894 /* BSD sum algorithm ('sum' Unix command) */
1895 sum = (sum >> 1) | (sum << 15);
54f7b4a3 1896 sum += val;
e4cf1adc 1897 }
376253ec 1898 monitor_printf(mon, "%05d\n", sum);
e4cf1adc
FB
1899}
1900
13224a87
FB
1901static int mouse_button_state;
1902
3e5a50d6 1903static void hmp_mouse_move(Monitor *mon, const QDict *qdict)
13224a87 1904{
c751a74a 1905 int dx, dy, dz, button;
1d4daa91
LC
1906 const char *dx_str = qdict_get_str(qdict, "dx_str");
1907 const char *dy_str = qdict_get_str(qdict, "dy_str");
1908 const char *dz_str = qdict_get_try_str(qdict, "dz_str");
c751a74a 1909
13224a87
FB
1910 dx = strtol(dx_str, NULL, 0);
1911 dy = strtol(dy_str, NULL, 0);
c751a74a
GH
1912 qemu_input_queue_rel(NULL, INPUT_AXIS_X, dx);
1913 qemu_input_queue_rel(NULL, INPUT_AXIS_Y, dy);
1914
1915 if (dz_str) {
13224a87 1916 dz = strtol(dz_str, NULL, 0);
c751a74a 1917 if (dz != 0) {
f22d0af0 1918 button = (dz > 0) ? INPUT_BUTTON_WHEEL_UP : INPUT_BUTTON_WHEEL_DOWN;
c751a74a
GH
1919 qemu_input_queue_btn(NULL, button, true);
1920 qemu_input_event_sync();
1921 qemu_input_queue_btn(NULL, button, false);
1922 }
1923 }
1924 qemu_input_event_sync();
13224a87
FB
1925}
1926
3e5a50d6 1927static void hmp_mouse_button(Monitor *mon, const QDict *qdict)
13224a87 1928{
7fb1cf16 1929 static uint32_t bmap[INPUT_BUTTON__MAX] = {
c751a74a
GH
1930 [INPUT_BUTTON_LEFT] = MOUSE_EVENT_LBUTTON,
1931 [INPUT_BUTTON_MIDDLE] = MOUSE_EVENT_MBUTTON,
1932 [INPUT_BUTTON_RIGHT] = MOUSE_EVENT_RBUTTON,
1933 };
d54908a5 1934 int button_state = qdict_get_int(qdict, "button_state");
c751a74a
GH
1935
1936 if (mouse_button_state == button_state) {
1937 return;
1938 }
1939 qemu_input_update_buttons(NULL, bmap, mouse_button_state, button_state);
1940 qemu_input_event_sync();
13224a87 1941 mouse_button_state = button_state;
13224a87
FB
1942}
1943
3e5a50d6 1944static void hmp_ioport_read(Monitor *mon, const QDict *qdict)
3440557b 1945{
aa93e39c
LC
1946 int size = qdict_get_int(qdict, "size");
1947 int addr = qdict_get_int(qdict, "addr");
1948 int has_index = qdict_haskey(qdict, "index");
3440557b
FB
1949 uint32_t val;
1950 int suffix;
1951
1952 if (has_index) {
aa93e39c 1953 int index = qdict_get_int(qdict, "index");
afcea8cb 1954 cpu_outb(addr & IOPORTS_MASK, index & 0xff);
3440557b
FB
1955 addr++;
1956 }
1957 addr &= 0xffff;
1958
1959 switch(size) {
1960 default:
1961 case 1:
afcea8cb 1962 val = cpu_inb(addr);
3440557b
FB
1963 suffix = 'b';
1964 break;
1965 case 2:
afcea8cb 1966 val = cpu_inw(addr);
3440557b
FB
1967 suffix = 'w';
1968 break;
1969 case 4:
afcea8cb 1970 val = cpu_inl(addr);
3440557b
FB
1971 suffix = 'l';
1972 break;
1973 }
376253ec
AL
1974 monitor_printf(mon, "port%c[0x%04x] = %#0*x\n",
1975 suffix, addr, size * 2, val);
3440557b 1976}
a3a91a35 1977
3e5a50d6 1978static void hmp_ioport_write(Monitor *mon, const QDict *qdict)
f114784f 1979{
1bd1442e
LC
1980 int size = qdict_get_int(qdict, "size");
1981 int addr = qdict_get_int(qdict, "addr");
1982 int val = qdict_get_int(qdict, "val");
1983
f114784f
JK
1984 addr &= IOPORTS_MASK;
1985
1986 switch (size) {
1987 default:
1988 case 1:
afcea8cb 1989 cpu_outb(addr, val);
f114784f
JK
1990 break;
1991 case 2:
afcea8cb 1992 cpu_outw(addr, val);
f114784f
JK
1993 break;
1994 case 4:
afcea8cb 1995 cpu_outl(addr, val);
f114784f
JK
1996 break;
1997 }
1998}
1999
3e5a50d6 2000static void hmp_boot_set(Monitor *mon, const QDict *qdict)
0ecdffbb 2001{
f1839938 2002 Error *local_err = NULL;
d54908a5 2003 const char *bootdevice = qdict_get_str(qdict, "bootdevice");
0ecdffbb 2004
f1839938
GA
2005 qemu_boot_set(bootdevice, &local_err);
2006 if (local_err) {
193227f9 2007 error_report_err(local_err);
0ecdffbb 2008 } else {
f1839938 2009 monitor_printf(mon, "boot device list now set to %s\n", bootdevice);
0ecdffbb
AJ
2010 }
2011}
2012
1ce6be24 2013static void hmp_info_mtree(Monitor *mon, const QDict *qdict)
314e2987 2014{
57bb40c9 2015 bool flatview = qdict_get_try_bool(qdict, "flatview", false);
5e8fd947 2016 bool dispatch_tree = qdict_get_try_bool(qdict, "dispatch_tree", false);
fc051ae6 2017 bool owner = qdict_get_try_bool(qdict, "owner", false);
57bb40c9 2018
fc051ae6
AK
2019 mtree_info((fprintf_function)monitor_printf, mon, flatview, dispatch_tree,
2020 owner);
314e2987
BS
2021}
2022
1ce6be24 2023static void hmp_info_numa(Monitor *mon, const QDict *qdict)
030ea37b 2024{
b28b6230 2025 int i;
31959e82 2026 NumaNodeMem *node_mem;
f75cd44d 2027 CpuInfoList *cpu_list, *cpu;
030ea37b 2028
f75cd44d 2029 cpu_list = qmp_query_cpus(&error_abort);
31959e82
VG
2030 node_mem = g_new0(NumaNodeMem, nb_numa_nodes);
2031
5b009e40 2032 query_numa_node_mem(node_mem);
030ea37b
AL
2033 monitor_printf(mon, "%d nodes\n", nb_numa_nodes);
2034 for (i = 0; i < nb_numa_nodes; i++) {
2035 monitor_printf(mon, "node %d cpus:", i);
f75cd44d
IM
2036 for (cpu = cpu_list; cpu; cpu = cpu->next) {
2037 if (cpu->value->has_props && cpu->value->props->has_node_id &&
2038 cpu->value->props->node_id == i) {
2039 monitor_printf(mon, " %" PRIi64, cpu->value->CPU);
030ea37b
AL
2040 }
2041 }
2042 monitor_printf(mon, "\n");
2043 monitor_printf(mon, "node %d size: %" PRId64 " MB\n", i,
31959e82
VG
2044 node_mem[i].node_mem >> 20);
2045 monitor_printf(mon, "node %d plugged: %" PRId64 " MB\n", i,
2046 node_mem[i].node_plugged_mem >> 20);
030ea37b 2047 }
f75cd44d 2048 qapi_free_CpuInfoList(cpu_list);
5b009e40 2049 g_free(node_mem);
030ea37b
AL
2050}
2051
5f1ce948
FB
2052#ifdef CONFIG_PROFILER
2053
89d5cbdd 2054int64_t tcg_time;
e9a6625e
AJ
2055int64_t dev_time;
2056
1ce6be24 2057static void hmp_info_profile(Monitor *mon, const QDict *qdict)
5f1ce948 2058{
376253ec 2059 monitor_printf(mon, "async time %" PRId64 " (%0.3f)\n",
73bcb24d 2060 dev_time, dev_time / (double)NANOSECONDS_PER_SECOND);
376253ec 2061 monitor_printf(mon, "qemu time %" PRId64 " (%0.3f)\n",
73bcb24d 2062 tcg_time, tcg_time / (double)NANOSECONDS_PER_SECOND);
89d5cbdd 2063 tcg_time = 0;
5f1ce948 2064 dev_time = 0;
5f1ce948
FB
2065}
2066#else
1ce6be24 2067static void hmp_info_profile(Monitor *mon, const QDict *qdict)
5f1ce948 2068{
376253ec 2069 monitor_printf(mon, "Internal profiler not compiled\n");
5f1ce948
FB
2070}
2071#endif
2072
ec36b695 2073/* Capture support */
72cf2d4f 2074static QLIST_HEAD (capture_list_head, CaptureState) capture_head;
ec36b695 2075
1ce6be24 2076static void hmp_info_capture(Monitor *mon, const QDict *qdict)
ec36b695
FB
2077{
2078 int i;
2079 CaptureState *s;
2080
2081 for (s = capture_head.lh_first, i = 0; s; s = s->entries.le_next, ++i) {
376253ec 2082 monitor_printf(mon, "[%d]: ", i);
ec36b695
FB
2083 s->ops.info (s->opaque);
2084 }
2085}
2086
3e5a50d6 2087static void hmp_stopcapture(Monitor *mon, const QDict *qdict)
ec36b695
FB
2088{
2089 int i;
d54908a5 2090 int n = qdict_get_int(qdict, "n");
ec36b695
FB
2091 CaptureState *s;
2092
2093 for (s = capture_head.lh_first, i = 0; s; s = s->entries.le_next, ++i) {
2094 if (i == n) {
2095 s->ops.destroy (s->opaque);
72cf2d4f 2096 QLIST_REMOVE (s, entries);
7267c094 2097 g_free (s);
ec36b695
FB
2098 return;
2099 }
2100 }
2101}
2102
3e5a50d6 2103static void hmp_wavcapture(Monitor *mon, const QDict *qdict)
c1925484
LC
2104{
2105 const char *path = qdict_get_str(qdict, "path");
2106 int has_freq = qdict_haskey(qdict, "freq");
2107 int freq = qdict_get_try_int(qdict, "freq", -1);
2108 int has_bits = qdict_haskey(qdict, "bits");
2109 int bits = qdict_get_try_int(qdict, "bits", -1);
2110 int has_channels = qdict_haskey(qdict, "nchannels");
2111 int nchannels = qdict_get_try_int(qdict, "nchannels", -1);
ec36b695
FB
2112 CaptureState *s;
2113
7267c094 2114 s = g_malloc0 (sizeof (*s));
ec36b695
FB
2115
2116 freq = has_freq ? freq : 44100;
2117 bits = has_bits ? bits : 16;
2118 nchannels = has_channels ? nchannels : 2;
2119
2120 if (wav_start_capture (s, path, freq, bits, nchannels)) {
d00b2618 2121 monitor_printf(mon, "Failed to add wave capture\n");
7267c094 2122 g_free (s);
d00b2618 2123 return;
ec36b695 2124 }
72cf2d4f 2125 QLIST_INSERT_HEAD (&capture_head, s, entries);
ec36b695 2126}
ec36b695 2127
15dfcd45 2128static qemu_acl *find_acl(Monitor *mon, const char *name)
76655d6d 2129{
15dfcd45 2130 qemu_acl *acl = qemu_acl_find(name);
76655d6d 2131
76655d6d 2132 if (!acl) {
15dfcd45 2133 monitor_printf(mon, "acl: unknown list '%s'\n", name);
76655d6d 2134 }
15dfcd45
JK
2135 return acl;
2136}
2137
3e5a50d6 2138static void hmp_acl_show(Monitor *mon, const QDict *qdict)
15dfcd45 2139{
d54908a5 2140 const char *aclname = qdict_get_str(qdict, "aclname");
15dfcd45
JK
2141 qemu_acl *acl = find_acl(mon, aclname);
2142 qemu_acl_entry *entry;
2143 int i = 0;
76655d6d 2144
15dfcd45 2145 if (acl) {
28a76be8 2146 monitor_printf(mon, "policy: %s\n",
76655d6d 2147 acl->defaultDeny ? "deny" : "allow");
72cf2d4f 2148 QTAILQ_FOREACH(entry, &acl->entries, next) {
28a76be8
AL
2149 i++;
2150 monitor_printf(mon, "%d: %s %s\n", i,
15dfcd45 2151 entry->deny ? "deny" : "allow", entry->match);
28a76be8 2152 }
15dfcd45
JK
2153 }
2154}
2155
3e5a50d6 2156static void hmp_acl_reset(Monitor *mon, const QDict *qdict)
15dfcd45 2157{
d54908a5 2158 const char *aclname = qdict_get_str(qdict, "aclname");
15dfcd45
JK
2159 qemu_acl *acl = find_acl(mon, aclname);
2160
2161 if (acl) {
28a76be8
AL
2162 qemu_acl_reset(acl);
2163 monitor_printf(mon, "acl: removed all rules\n");
15dfcd45
JK
2164 }
2165}
2166
3e5a50d6 2167static void hmp_acl_policy(Monitor *mon, const QDict *qdict)
15dfcd45 2168{
f18c16de
LC
2169 const char *aclname = qdict_get_str(qdict, "aclname");
2170 const char *policy = qdict_get_str(qdict, "policy");
15dfcd45 2171 qemu_acl *acl = find_acl(mon, aclname);
28a76be8 2172
15dfcd45
JK
2173 if (acl) {
2174 if (strcmp(policy, "allow") == 0) {
28a76be8
AL
2175 acl->defaultDeny = 0;
2176 monitor_printf(mon, "acl: policy set to 'allow'\n");
15dfcd45 2177 } else if (strcmp(policy, "deny") == 0) {
28a76be8
AL
2178 acl->defaultDeny = 1;
2179 monitor_printf(mon, "acl: policy set to 'deny'\n");
2180 } else {
15dfcd45
JK
2181 monitor_printf(mon, "acl: unknown policy '%s', "
2182 "expected 'deny' or 'allow'\n", policy);
28a76be8 2183 }
15dfcd45
JK
2184 }
2185}
28a76be8 2186
3e5a50d6 2187static void hmp_acl_add(Monitor *mon, const QDict *qdict)
15dfcd45 2188{
1bd1442e
LC
2189 const char *aclname = qdict_get_str(qdict, "aclname");
2190 const char *match = qdict_get_str(qdict, "match");
2191 const char *policy = qdict_get_str(qdict, "policy");
2192 int has_index = qdict_haskey(qdict, "index");
2193 int index = qdict_get_try_int(qdict, "index", -1);
15dfcd45
JK
2194 qemu_acl *acl = find_acl(mon, aclname);
2195 int deny, ret;
2196
2197 if (acl) {
2198 if (strcmp(policy, "allow") == 0) {
2199 deny = 0;
2200 } else if (strcmp(policy, "deny") == 0) {
2201 deny = 1;
2202 } else {
2203 monitor_printf(mon, "acl: unknown policy '%s', "
2204 "expected 'deny' or 'allow'\n", policy);
28a76be8
AL
2205 return;
2206 }
28a76be8
AL
2207 if (has_index)
2208 ret = qemu_acl_insert(acl, deny, match, index);
2209 else
2210 ret = qemu_acl_append(acl, deny, match);
2211 if (ret < 0)
2212 monitor_printf(mon, "acl: unable to add acl entry\n");
2213 else
2214 monitor_printf(mon, "acl: added rule at position %d\n", ret);
15dfcd45
JK
2215 }
2216}
28a76be8 2217
3e5a50d6 2218static void hmp_acl_remove(Monitor *mon, const QDict *qdict)
15dfcd45 2219{
f18c16de
LC
2220 const char *aclname = qdict_get_str(qdict, "aclname");
2221 const char *match = qdict_get_str(qdict, "match");
15dfcd45
JK
2222 qemu_acl *acl = find_acl(mon, aclname);
2223 int ret;
28a76be8 2224
15dfcd45 2225 if (acl) {
28a76be8
AL
2226 ret = qemu_acl_remove(acl, match);
2227 if (ret < 0)
2228 monitor_printf(mon, "acl: no matching acl entry\n");
2229 else
2230 monitor_printf(mon, "acl: removed rule at position %d\n", ret);
76655d6d
AL
2231 }
2232}
2233
208c9d1b 2234void qmp_getfd(const char *fdname, Error **errp)
f07918fd 2235{
c227f099 2236 mon_fd_t *monfd;
9409fc05 2237 int fd, tmp_fd;
f07918fd 2238
5345fdb4 2239 fd = qemu_chr_fe_get_msgfd(&cur_mon->chr);
f07918fd 2240 if (fd == -1) {
c6bd8c70 2241 error_setg(errp, QERR_FD_NOT_SUPPLIED);
208c9d1b 2242 return;
f07918fd
MM
2243 }
2244
2245 if (qemu_isdigit(fdname[0])) {
0b9f0e2f 2246 close(fd);
c6bd8c70
MA
2247 error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "fdname",
2248 "a name not starting with a digit");
208c9d1b 2249 return;
f07918fd
MM
2250 }
2251
9409fc05 2252 qemu_mutex_lock(&cur_mon->mon_lock);
208c9d1b 2253 QLIST_FOREACH(monfd, &cur_mon->fds, next) {
f07918fd
MM
2254 if (strcmp(monfd->name, fdname) != 0) {
2255 continue;
2256 }
2257
9409fc05 2258 tmp_fd = monfd->fd;
f07918fd 2259 monfd->fd = fd;
9409fc05 2260 qemu_mutex_unlock(&cur_mon->mon_lock);
774a6b67 2261 /* Make sure close() is outside critical section */
9409fc05 2262 close(tmp_fd);
208c9d1b 2263 return;
f07918fd
MM
2264 }
2265
7267c094
AL
2266 monfd = g_malloc0(sizeof(mon_fd_t));
2267 monfd->name = g_strdup(fdname);
f07918fd
MM
2268 monfd->fd = fd;
2269
208c9d1b 2270 QLIST_INSERT_HEAD(&cur_mon->fds, monfd, next);
9409fc05 2271 qemu_mutex_unlock(&cur_mon->mon_lock);
f07918fd
MM
2272}
2273
208c9d1b 2274void qmp_closefd(const char *fdname, Error **errp)
f07918fd 2275{
c227f099 2276 mon_fd_t *monfd;
9409fc05 2277 int tmp_fd;
f07918fd 2278
9409fc05 2279 qemu_mutex_lock(&cur_mon->mon_lock);
208c9d1b 2280 QLIST_FOREACH(monfd, &cur_mon->fds, next) {
f07918fd
MM
2281 if (strcmp(monfd->name, fdname) != 0) {
2282 continue;
2283 }
2284
72cf2d4f 2285 QLIST_REMOVE(monfd, next);
9409fc05 2286 tmp_fd = monfd->fd;
7267c094
AL
2287 g_free(monfd->name);
2288 g_free(monfd);
9409fc05 2289 qemu_mutex_unlock(&cur_mon->mon_lock);
774a6b67 2290 /* Make sure close() is outside critical section */
9409fc05 2291 close(tmp_fd);
208c9d1b 2292 return;
f07918fd
MM
2293 }
2294
9409fc05 2295 qemu_mutex_unlock(&cur_mon->mon_lock);
c6bd8c70 2296 error_setg(errp, QERR_FD_NOT_FOUND, fdname);
f07918fd
MM
2297}
2298
a9940fc4 2299int monitor_get_fd(Monitor *mon, const char *fdname, Error **errp)
7768e04c 2300{
c227f099 2301 mon_fd_t *monfd;
7768e04c 2302
9409fc05 2303 qemu_mutex_lock(&mon->mon_lock);
72cf2d4f 2304 QLIST_FOREACH(monfd, &mon->fds, next) {
7768e04c
MM
2305 int fd;
2306
2307 if (strcmp(monfd->name, fdname) != 0) {
2308 continue;
2309 }
2310
2311 fd = monfd->fd;
2312
2313 /* caller takes ownership of fd */
72cf2d4f 2314 QLIST_REMOVE(monfd, next);
7267c094
AL
2315 g_free(monfd->name);
2316 g_free(monfd);
9409fc05 2317 qemu_mutex_unlock(&mon->mon_lock);
7768e04c
MM
2318
2319 return fd;
2320 }
2321
9409fc05 2322 qemu_mutex_unlock(&mon->mon_lock);
a9940fc4 2323 error_setg(errp, "File descriptor named '%s' has not been found", fdname);
7768e04c
MM
2324 return -1;
2325}
2326
ba1c048a
CB
2327static void monitor_fdset_cleanup(MonFdset *mon_fdset)
2328{
2329 MonFdsetFd *mon_fdset_fd;
2330 MonFdsetFd *mon_fdset_fd_next;
2331
2332 QLIST_FOREACH_SAFE(mon_fdset_fd, &mon_fdset->fds, next, mon_fdset_fd_next) {
ebe52b59
CB
2333 if ((mon_fdset_fd->removed ||
2334 (QLIST_EMPTY(&mon_fdset->dup_fds) && mon_refcount == 0)) &&
2335 runstate_is_running()) {
ba1c048a
CB
2336 close(mon_fdset_fd->fd);
2337 g_free(mon_fdset_fd->opaque);
2338 QLIST_REMOVE(mon_fdset_fd, next);
2339 g_free(mon_fdset_fd);
2340 }
2341 }
2342
adb696f3 2343 if (QLIST_EMPTY(&mon_fdset->fds) && QLIST_EMPTY(&mon_fdset->dup_fds)) {
ba1c048a
CB
2344 QLIST_REMOVE(mon_fdset, next);
2345 g_free(mon_fdset);
2346 }
2347}
2348
efb87c16
CB
2349static void monitor_fdsets_cleanup(void)
2350{
2351 MonFdset *mon_fdset;
2352 MonFdset *mon_fdset_next;
2353
47451466 2354 qemu_mutex_lock(&mon_fdsets_lock);
efb87c16
CB
2355 QLIST_FOREACH_SAFE(mon_fdset, &mon_fdsets, next, mon_fdset_next) {
2356 monitor_fdset_cleanup(mon_fdset);
2357 }
47451466 2358 qemu_mutex_unlock(&mon_fdsets_lock);
efb87c16
CB
2359}
2360
ba1c048a
CB
2361AddfdInfo *qmp_add_fd(bool has_fdset_id, int64_t fdset_id, bool has_opaque,
2362 const char *opaque, Error **errp)
2363{
2364 int fd;
2365 Monitor *mon = cur_mon;
ba1c048a
CB
2366 AddfdInfo *fdinfo;
2367
5345fdb4 2368 fd = qemu_chr_fe_get_msgfd(&mon->chr);
ba1c048a 2369 if (fd == -1) {
c6bd8c70 2370 error_setg(errp, QERR_FD_NOT_SUPPLIED);
ba1c048a
CB
2371 goto error;
2372 }
2373
e446f70d
CB
2374 fdinfo = monitor_fdset_add_fd(fd, has_fdset_id, fdset_id,
2375 has_opaque, opaque, errp);
2376 if (fdinfo) {
2377 return fdinfo;
ba1c048a 2378 }
ba1c048a
CB
2379
2380error:
2381 if (fd != -1) {
2382 close(fd);
2383 }
2384 return NULL;
2385}
2386
2387void qmp_remove_fd(int64_t fdset_id, bool has_fd, int64_t fd, Error **errp)
2388{
2389 MonFdset *mon_fdset;
2390 MonFdsetFd *mon_fdset_fd;
2391 char fd_str[60];
2392
47451466 2393 qemu_mutex_lock(&mon_fdsets_lock);
ba1c048a
CB
2394 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2395 if (mon_fdset->id != fdset_id) {
2396 continue;
2397 }
2398 QLIST_FOREACH(mon_fdset_fd, &mon_fdset->fds, next) {
2399 if (has_fd) {
2400 if (mon_fdset_fd->fd != fd) {
2401 continue;
2402 }
2403 mon_fdset_fd->removed = true;
2404 break;
2405 } else {
2406 mon_fdset_fd->removed = true;
2407 }
2408 }
2409 if (has_fd && !mon_fdset_fd) {
2410 goto error;
2411 }
2412 monitor_fdset_cleanup(mon_fdset);
47451466 2413 qemu_mutex_unlock(&mon_fdsets_lock);
ba1c048a
CB
2414 return;
2415 }
2416
2417error:
47451466 2418 qemu_mutex_unlock(&mon_fdsets_lock);
ba1c048a
CB
2419 if (has_fd) {
2420 snprintf(fd_str, sizeof(fd_str), "fdset-id:%" PRId64 ", fd:%" PRId64,
2421 fdset_id, fd);
2422 } else {
2423 snprintf(fd_str, sizeof(fd_str), "fdset-id:%" PRId64, fdset_id);
2424 }
c6bd8c70 2425 error_setg(errp, QERR_FD_NOT_FOUND, fd_str);
ba1c048a
CB
2426}
2427
2428FdsetInfoList *qmp_query_fdsets(Error **errp)
2429{
2430 MonFdset *mon_fdset;
2431 MonFdsetFd *mon_fdset_fd;
2432 FdsetInfoList *fdset_list = NULL;
2433
47451466 2434 qemu_mutex_lock(&mon_fdsets_lock);
ba1c048a
CB
2435 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2436 FdsetInfoList *fdset_info = g_malloc0(sizeof(*fdset_info));
2437 FdsetFdInfoList *fdsetfd_list = NULL;
2438
2439 fdset_info->value = g_malloc0(sizeof(*fdset_info->value));
2440 fdset_info->value->fdset_id = mon_fdset->id;
2441
2442 QLIST_FOREACH(mon_fdset_fd, &mon_fdset->fds, next) {
2443 FdsetFdInfoList *fdsetfd_info;
2444
2445 fdsetfd_info = g_malloc0(sizeof(*fdsetfd_info));
2446 fdsetfd_info->value = g_malloc0(sizeof(*fdsetfd_info->value));
2447 fdsetfd_info->value->fd = mon_fdset_fd->fd;
2448 if (mon_fdset_fd->opaque) {
2449 fdsetfd_info->value->has_opaque = true;
2450 fdsetfd_info->value->opaque = g_strdup(mon_fdset_fd->opaque);
2451 } else {
2452 fdsetfd_info->value->has_opaque = false;
2453 }
2454
2455 fdsetfd_info->next = fdsetfd_list;
2456 fdsetfd_list = fdsetfd_info;
2457 }
2458
2459 fdset_info->value->fds = fdsetfd_list;
2460
2461 fdset_info->next = fdset_list;
2462 fdset_list = fdset_info;
2463 }
47451466 2464 qemu_mutex_unlock(&mon_fdsets_lock);
ba1c048a
CB
2465
2466 return fdset_list;
2467}
2468
e446f70d
CB
2469AddfdInfo *monitor_fdset_add_fd(int fd, bool has_fdset_id, int64_t fdset_id,
2470 bool has_opaque, const char *opaque,
2471 Error **errp)
2472{
2473 MonFdset *mon_fdset = NULL;
2474 MonFdsetFd *mon_fdset_fd;
2475 AddfdInfo *fdinfo;
2476
47451466 2477 qemu_mutex_lock(&mon_fdsets_lock);
e446f70d
CB
2478 if (has_fdset_id) {
2479 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2480 /* Break if match found or match impossible due to ordering by ID */
2481 if (fdset_id <= mon_fdset->id) {
2482 if (fdset_id < mon_fdset->id) {
2483 mon_fdset = NULL;
2484 }
2485 break;
2486 }
2487 }
2488 }
2489
2490 if (mon_fdset == NULL) {
2491 int64_t fdset_id_prev = -1;
2492 MonFdset *mon_fdset_cur = QLIST_FIRST(&mon_fdsets);
2493
2494 if (has_fdset_id) {
2495 if (fdset_id < 0) {
c6bd8c70
MA
2496 error_setg(errp, QERR_INVALID_PARAMETER_VALUE, "fdset-id",
2497 "a non-negative value");
47451466 2498 qemu_mutex_unlock(&mon_fdsets_lock);
e446f70d
CB
2499 return NULL;
2500 }
2501 /* Use specified fdset ID */
2502 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2503 mon_fdset_cur = mon_fdset;
2504 if (fdset_id < mon_fdset_cur->id) {
2505 break;
2506 }
2507 }
2508 } else {
2509 /* Use first available fdset ID */
2510 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2511 mon_fdset_cur = mon_fdset;
2512 if (fdset_id_prev == mon_fdset_cur->id - 1) {
2513 fdset_id_prev = mon_fdset_cur->id;
2514 continue;
2515 }
2516 break;
2517 }
2518 }
2519
2520 mon_fdset = g_malloc0(sizeof(*mon_fdset));
2521 if (has_fdset_id) {
2522 mon_fdset->id = fdset_id;
2523 } else {
2524 mon_fdset->id = fdset_id_prev + 1;
2525 }
2526
2527 /* The fdset list is ordered by fdset ID */
2528 if (!mon_fdset_cur) {
2529 QLIST_INSERT_HEAD(&mon_fdsets, mon_fdset, next);
2530 } else if (mon_fdset->id < mon_fdset_cur->id) {
2531 QLIST_INSERT_BEFORE(mon_fdset_cur, mon_fdset, next);
2532 } else {
2533 QLIST_INSERT_AFTER(mon_fdset_cur, mon_fdset, next);
2534 }
2535 }
2536
2537 mon_fdset_fd = g_malloc0(sizeof(*mon_fdset_fd));
2538 mon_fdset_fd->fd = fd;
2539 mon_fdset_fd->removed = false;
2540 if (has_opaque) {
2541 mon_fdset_fd->opaque = g_strdup(opaque);
2542 }
2543 QLIST_INSERT_HEAD(&mon_fdset->fds, mon_fdset_fd, next);
2544
2545 fdinfo = g_malloc0(sizeof(*fdinfo));
2546 fdinfo->fdset_id = mon_fdset->id;
2547 fdinfo->fd = mon_fdset_fd->fd;
2548
47451466 2549 qemu_mutex_unlock(&mon_fdsets_lock);
e446f70d
CB
2550 return fdinfo;
2551}
2552
adb696f3
CB
2553int monitor_fdset_get_fd(int64_t fdset_id, int flags)
2554{
47451466
PX
2555#ifdef _WIN32
2556 return -ENOENT;
2557#else
adb696f3
CB
2558 MonFdset *mon_fdset;
2559 MonFdsetFd *mon_fdset_fd;
2560 int mon_fd_flags;
47451466 2561 int ret;
adb696f3 2562
47451466 2563 qemu_mutex_lock(&mon_fdsets_lock);
adb696f3
CB
2564 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2565 if (mon_fdset->id != fdset_id) {
2566 continue;
2567 }
2568 QLIST_FOREACH(mon_fdset_fd, &mon_fdset->fds, next) {
2569 mon_fd_flags = fcntl(mon_fdset_fd->fd, F_GETFL);
2570 if (mon_fd_flags == -1) {
47451466
PX
2571 ret = -errno;
2572 goto out;
adb696f3
CB
2573 }
2574
2575 if ((flags & O_ACCMODE) == (mon_fd_flags & O_ACCMODE)) {
47451466
PX
2576 ret = mon_fdset_fd->fd;
2577 goto out;
adb696f3
CB
2578 }
2579 }
47451466
PX
2580 ret = -EACCES;
2581 goto out;
adb696f3 2582 }
47451466 2583 ret = -ENOENT;
adb696f3 2584
47451466
PX
2585out:
2586 qemu_mutex_unlock(&mon_fdsets_lock);
2587 return ret;
2588#endif
adb696f3
CB
2589}
2590
2591int monitor_fdset_dup_fd_add(int64_t fdset_id, int dup_fd)
2592{
2593 MonFdset *mon_fdset;
2594 MonFdsetFd *mon_fdset_fd_dup;
2595
47451466 2596 qemu_mutex_lock(&mon_fdsets_lock);
adb696f3
CB
2597 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2598 if (mon_fdset->id != fdset_id) {
2599 continue;
2600 }
2601 QLIST_FOREACH(mon_fdset_fd_dup, &mon_fdset->dup_fds, next) {
2602 if (mon_fdset_fd_dup->fd == dup_fd) {
47451466 2603 goto err;
adb696f3
CB
2604 }
2605 }
2606 mon_fdset_fd_dup = g_malloc0(sizeof(*mon_fdset_fd_dup));
2607 mon_fdset_fd_dup->fd = dup_fd;
2608 QLIST_INSERT_HEAD(&mon_fdset->dup_fds, mon_fdset_fd_dup, next);
47451466 2609 qemu_mutex_unlock(&mon_fdsets_lock);
adb696f3
CB
2610 return 0;
2611 }
47451466
PX
2612
2613err:
2614 qemu_mutex_unlock(&mon_fdsets_lock);
adb696f3
CB
2615 return -1;
2616}
2617
2618static int monitor_fdset_dup_fd_find_remove(int dup_fd, bool remove)
2619{
2620 MonFdset *mon_fdset;
2621 MonFdsetFd *mon_fdset_fd_dup;
2622
47451466 2623 qemu_mutex_lock(&mon_fdsets_lock);
adb696f3
CB
2624 QLIST_FOREACH(mon_fdset, &mon_fdsets, next) {
2625 QLIST_FOREACH(mon_fdset_fd_dup, &mon_fdset->dup_fds, next) {
2626 if (mon_fdset_fd_dup->fd == dup_fd) {
2627 if (remove) {
2628 QLIST_REMOVE(mon_fdset_fd_dup, next);
2629 if (QLIST_EMPTY(&mon_fdset->dup_fds)) {
2630 monitor_fdset_cleanup(mon_fdset);
2631 }
47451466 2632 goto err;
b3dd1b8c 2633 } else {
47451466 2634 qemu_mutex_unlock(&mon_fdsets_lock);
b3dd1b8c 2635 return mon_fdset->id;
adb696f3 2636 }
adb696f3
CB
2637 }
2638 }
2639 }
47451466
PX
2640
2641err:
2642 qemu_mutex_unlock(&mon_fdsets_lock);
adb696f3
CB
2643 return -1;
2644}
2645
2646int monitor_fdset_dup_fd_find(int dup_fd)
2647{
2648 return monitor_fdset_dup_fd_find_remove(dup_fd, false);
2649}
2650
b3dd1b8c 2651void monitor_fdset_dup_fd_remove(int dup_fd)
adb696f3 2652{
b3dd1b8c 2653 monitor_fdset_dup_fd_find_remove(dup_fd, true);
adb696f3
CB
2654}
2655
1677f4c6 2656int monitor_fd_param(Monitor *mon, const char *fdname, Error **errp)
5906366e
LE
2657{
2658 int fd;
2659 Error *local_err = NULL;
a96ed02f 2660
5906366e 2661 if (!qemu_isdigit(fdname[0]) && mon) {
a9940fc4 2662 fd = monitor_get_fd(mon, fdname, &local_err);
5906366e
LE
2663 } else {
2664 fd = qemu_parse_fd(fdname);
a96ed02f 2665 if (fd == -1) {
5906366e
LE
2666 error_setg(&local_err, "Invalid file descriptor number '%s'",
2667 fdname);
a96ed02f 2668 }
5906366e
LE
2669 }
2670 if (local_err) {
2671 error_propagate(errp, local_err);
2672 assert(fd == -1);
a96ed02f 2673 } else {
5906366e 2674 assert(fd != -1);
a96ed02f
NB
2675 }
2676
2677 return fd;
2678}
2679
acd0a093 2680/* Please update hmp-commands.hx when adding or changing commands */
816f8925 2681static mon_cmd_t info_cmds[] = {
da76ee76
PB
2682#include "hmp-commands-info.h"
2683 { NULL, NULL, },
9dc39cba
FB
2684};
2685
a13ced59
WX
2686/* mon_cmds and info_cmds would be sorted at runtime */
2687static mon_cmd_t mon_cmds[] = {
2688#include "hmp-commands.h"
2689 { NULL, NULL, },
2690};
2691
9307c4c1
FB
2692/*******************************************************************/
2693
2694static const char *pch;
6ab7e546 2695static sigjmp_buf expr_env;
9307c4c1 2696
9307c4c1 2697
9c3175cc
SW
2698static void GCC_FMT_ATTR(2, 3) QEMU_NORETURN
2699expr_error(Monitor *mon, const char *fmt, ...)
9dc39cba 2700{
277acfe8
FZ
2701 va_list ap;
2702 va_start(ap, fmt);
2703 monitor_vprintf(mon, fmt, ap);
2704 monitor_printf(mon, "\n");
2705 va_end(ap);
6ab7e546 2706 siglongjmp(expr_env, 1);
9307c4c1
FB
2707}
2708
09b9418c 2709/* return 0 if OK, -1 if not found */
92a31b1f 2710static int get_monitor_def(target_long *pval, const char *name)
9307c4c1 2711{
bf957284 2712 const MonitorDef *md = target_monitor_defs();
854e67fe 2713 CPUState *cs = mon_get_cpu();
92a31b1f 2714 void *ptr;
0a9516c2
AK
2715 uint64_t tmp = 0;
2716 int ret;
92a31b1f 2717
854e67fe 2718 if (cs == NULL || md == NULL) {
bf957284
PB
2719 return -1;
2720 }
2721
2722 for(; md->name != NULL; md++) {
9307c4c1
FB
2723 if (compare_cmd(name, md->name)) {
2724 if (md->get_value) {
e95c8d51 2725 *pval = md->get_value(md, md->offset);
9307c4c1 2726 } else {
5bcda5f7 2727 CPUArchState *env = mon_get_cpu_env();
6a00d601 2728 ptr = (uint8_t *)env + md->offset;
92a31b1f
FB
2729 switch(md->type) {
2730 case MD_I32:
2731 *pval = *(int32_t *)ptr;
2732 break;
2733 case MD_TLONG:
2734 *pval = *(target_long *)ptr;
2735 break;
2736 default:
2737 *pval = 0;
2738 break;
2739 }
9307c4c1
FB
2740 }
2741 return 0;
2742 }
2743 }
0a9516c2 2744
854e67fe 2745 ret = target_get_monitor_def(cs, name, &tmp);
0a9516c2
AK
2746 if (!ret) {
2747 *pval = (target_long) tmp;
2748 }
2749
2750 return ret;
9307c4c1
FB
2751}
2752
2753static void next(void)
2754{
660f11be 2755 if (*pch != '\0') {
9307c4c1 2756 pch++;
cd390083 2757 while (qemu_isspace(*pch))
9307c4c1
FB
2758 pch++;
2759 }
2760}
2761
376253ec 2762static int64_t expr_sum(Monitor *mon);
9307c4c1 2763
376253ec 2764static int64_t expr_unary(Monitor *mon)
9307c4c1 2765{
c2efc95d 2766 int64_t n;
9307c4c1 2767 char *p;
6a00d601 2768 int ret;
9307c4c1
FB
2769
2770 switch(*pch) {
2771 case '+':
2772 next();
376253ec 2773 n = expr_unary(mon);
9307c4c1
FB
2774 break;
2775 case '-':
2776 next();
376253ec 2777 n = -expr_unary(mon);
9307c4c1
FB
2778 break;
2779 case '~':
2780 next();
376253ec 2781 n = ~expr_unary(mon);
9307c4c1
FB
2782 break;
2783 case '(':
2784 next();
376253ec 2785 n = expr_sum(mon);
9307c4c1 2786 if (*pch != ')') {
376253ec 2787 expr_error(mon, "')' expected");
9307c4c1
FB
2788 }
2789 next();
2790 break;
81d0912d
FB
2791 case '\'':
2792 pch++;
2793 if (*pch == '\0')
376253ec 2794 expr_error(mon, "character constant expected");
81d0912d
FB
2795 n = *pch;
2796 pch++;
2797 if (*pch != '\'')
376253ec 2798 expr_error(mon, "missing terminating \' character");
81d0912d
FB
2799 next();
2800 break;
9307c4c1
FB
2801 case '$':
2802 {
2803 char buf[128], *q;
69b34976 2804 target_long reg=0;
3b46e624 2805
9307c4c1
FB
2806 pch++;
2807 q = buf;
2808 while ((*pch >= 'a' && *pch <= 'z') ||
2809 (*pch >= 'A' && *pch <= 'Z') ||
2810 (*pch >= '0' && *pch <= '9') ||
57206fd4 2811 *pch == '_' || *pch == '.') {
9307c4c1
FB
2812 if ((q - buf) < sizeof(buf) - 1)
2813 *q++ = *pch;
2814 pch++;
2815 }
cd390083 2816 while (qemu_isspace(*pch))
9307c4c1
FB
2817 pch++;
2818 *q = 0;
7743e588 2819 ret = get_monitor_def(&reg, buf);
09b9418c 2820 if (ret < 0)
376253ec 2821 expr_error(mon, "unknown register");
7743e588 2822 n = reg;
9307c4c1
FB
2823 }
2824 break;
2825 case '\0':
376253ec 2826 expr_error(mon, "unexpected end of expression");
9307c4c1
FB
2827 n = 0;
2828 break;
2829 default:
6b0e33be 2830 errno = 0;
4f4fbf77 2831 n = strtoull(pch, &p, 0);
6b0e33be
LC
2832 if (errno == ERANGE) {
2833 expr_error(mon, "number too large");
2834 }
9307c4c1 2835 if (pch == p) {
277acfe8 2836 expr_error(mon, "invalid char '%c' in expression", *p);
9307c4c1
FB
2837 }
2838 pch = p;
cd390083 2839 while (qemu_isspace(*pch))
9307c4c1
FB
2840 pch++;
2841 break;
2842 }
2843 return n;
2844}
2845
2846
376253ec 2847static int64_t expr_prod(Monitor *mon)
9307c4c1 2848{
c2efc95d 2849 int64_t val, val2;
92a31b1f 2850 int op;
3b46e624 2851
376253ec 2852 val = expr_unary(mon);
9307c4c1
FB
2853 for(;;) {
2854 op = *pch;
2855 if (op != '*' && op != '/' && op != '%')
2856 break;
2857 next();
376253ec 2858 val2 = expr_unary(mon);
9307c4c1
FB
2859 switch(op) {
2860 default:
2861 case '*':
2862 val *= val2;
2863 break;
2864 case '/':
2865 case '%':
5fafdf24 2866 if (val2 == 0)
376253ec 2867 expr_error(mon, "division by zero");
9307c4c1
FB
2868 if (op == '/')
2869 val /= val2;
2870 else
2871 val %= val2;
2872 break;
2873 }
2874 }
2875 return val;
2876}
2877
376253ec 2878static int64_t expr_logic(Monitor *mon)
9307c4c1 2879{
c2efc95d 2880 int64_t val, val2;
92a31b1f 2881 int op;
9307c4c1 2882
376253ec 2883 val = expr_prod(mon);
9307c4c1
FB
2884 for(;;) {
2885 op = *pch;
2886 if (op != '&' && op != '|' && op != '^')
2887 break;
2888 next();
376253ec 2889 val2 = expr_prod(mon);
9307c4c1
FB
2890 switch(op) {
2891 default:
2892 case '&':
2893 val &= val2;
2894 break;
2895 case '|':
2896 val |= val2;
2897 break;
2898 case '^':
2899 val ^= val2;
2900 break;
2901 }
2902 }
2903 return val;
2904}
2905
376253ec 2906static int64_t expr_sum(Monitor *mon)
9307c4c1 2907{
c2efc95d 2908 int64_t val, val2;
92a31b1f 2909 int op;
9307c4c1 2910
376253ec 2911 val = expr_logic(mon);
9307c4c1
FB
2912 for(;;) {
2913 op = *pch;
2914 if (op != '+' && op != '-')
2915 break;
2916 next();
376253ec 2917 val2 = expr_logic(mon);
9307c4c1
FB
2918 if (op == '+')
2919 val += val2;
2920 else
2921 val -= val2;
2922 }
2923 return val;
2924}
2925
376253ec 2926static int get_expr(Monitor *mon, int64_t *pval, const char **pp)
9307c4c1
FB
2927{
2928 pch = *pp;
6ab7e546 2929 if (sigsetjmp(expr_env, 0)) {
9307c4c1
FB
2930 *pp = pch;
2931 return -1;
2932 }
cd390083 2933 while (qemu_isspace(*pch))
9307c4c1 2934 pch++;
376253ec 2935 *pval = expr_sum(mon);
9307c4c1
FB
2936 *pp = pch;
2937 return 0;
2938}
2939
3350a4dd
MA
2940static int get_double(Monitor *mon, double *pval, const char **pp)
2941{
2942 const char *p = *pp;
2943 char *tailp;
2944 double d;
2945
2946 d = strtod(p, &tailp);
2947 if (tailp == p) {
2948 monitor_printf(mon, "Number expected\n");
2949 return -1;
2950 }
2951 if (d != d || d - d != 0) {
2952 /* NaN or infinity */
2953 monitor_printf(mon, "Bad number\n");
2954 return -1;
2955 }
2956 *pval = d;
2957 *pp = tailp;
2958 return 0;
2959}
2960
4590fd80
LC
2961/*
2962 * Store the command-name in cmdname, and return a pointer to
2963 * the remaining of the command string.
2964 */
2965static const char *get_command_name(const char *cmdline,
2966 char *cmdname, size_t nlen)
2967{
2968 size_t len;
2969 const char *p, *pstart;
2970
2971 p = cmdline;
2972 while (qemu_isspace(*p))
2973 p++;
2974 if (*p == '\0')
2975 return NULL;
2976 pstart = p;
2977 while (*p != '\0' && *p != '/' && !qemu_isspace(*p))
2978 p++;
2979 len = p - pstart;
2980 if (len > nlen - 1)
2981 len = nlen - 1;
2982 memcpy(cmdname, pstart, len);
2983 cmdname[len] = '\0';
2984 return p;
2985}
2986
4d76d2ba
LC
2987/**
2988 * Read key of 'type' into 'key' and return the current
2989 * 'type' pointer.
2990 */
2991static char *key_get_info(const char *type, char **key)
2992{
2993 size_t len;
2994 char *p, *str;
2995
2996 if (*type == ',')
2997 type++;
2998
2999 p = strchr(type, ':');
3000 if (!p) {
3001 *key = NULL;
3002 return NULL;
3003 }
3004 len = p - type;
3005
7267c094 3006 str = g_malloc(len + 1);
4d76d2ba
LC
3007 memcpy(str, type, len);
3008 str[len] = '\0';
3009
3010 *key = str;
3011 return ++p;
3012}
3013
9307c4c1
FB
3014static int default_fmt_format = 'x';
3015static int default_fmt_size = 4;
3016
fbc3d96c
LS
3017static int is_valid_option(const char *c, const char *typestr)
3018{
3019 char option[3];
3020
3021 option[0] = '-';
3022 option[1] = *c;
3023 option[2] = '\0';
3024
3025 typestr = strstr(typestr, option);
3026 return (typestr != NULL);
3027}
3028
945c5ac8
LC
3029static const mon_cmd_t *search_dispatch_table(const mon_cmd_t *disp_table,
3030 const char *cmdname)
7fd669a1
LC
3031{
3032 const mon_cmd_t *cmd;
3033
945c5ac8 3034 for (cmd = disp_table; cmd->name != NULL; cmd++) {
7fd669a1
LC
3035 if (compare_cmd(cmdname, cmd->name)) {
3036 return cmd;
3037 }
3038 }
3039
3040 return NULL;
3041}
3042
5f3d335f 3043/*
ae50212f
BD
3044 * Parse command name from @cmdp according to command table @table.
3045 * If blank, return NULL.
3046 * Else, if no valid command can be found, report to @mon, and return
3047 * NULL.
3048 * Else, change @cmdp to point right behind the name, and return its
3049 * command table entry.
3050 * Do not assume the return value points into @table! It doesn't when
3051 * the command is found in a sub-command table.
5f3d335f 3052 */
c227f099 3053static const mon_cmd_t *monitor_parse_command(Monitor *mon,
250b8197 3054 const char *cmdp_start,
ae50212f
BD
3055 const char **cmdp,
3056 mon_cmd_t *table)
9307c4c1 3057{
ae50212f 3058 const char *p;
c227f099 3059 const mon_cmd_t *cmd;
9307c4c1 3060 char cmdname[256];
9dc39cba 3061
9307c4c1 3062 /* extract the command name */
ae50212f 3063 p = get_command_name(*cmdp, cmdname, sizeof(cmdname));
4590fd80 3064 if (!p)
55f81d96 3065 return NULL;
3b46e624 3066
5f3d335f 3067 cmd = search_dispatch_table(table, cmdname);
7fd669a1 3068 if (!cmd) {
5f3d335f 3069 monitor_printf(mon, "unknown command: '%.*s'\n",
250b8197 3070 (int)(p - cmdp_start), cmdp_start);
55f81d96 3071 return NULL;
9307c4c1 3072 }
c3120f71
DDAG
3073 if (runstate_check(RUN_STATE_PRECONFIG) && !cmd_can_preconfig(cmd)) {
3074 monitor_printf(mon, "Command '%.*s' not available with -preconfig "
3075 "until after exit_preconfig.\n",
3076 (int)(p - cmdp_start), cmdp_start);
3077 return NULL;
3078 }
9307c4c1 3079
5f3d335f
WX
3080 /* filter out following useless space */
3081 while (qemu_isspace(*p)) {
3082 p++;
3083 }
ae50212f
BD
3084
3085 *cmdp = p;
5f3d335f 3086 /* search sub command */
ae50212f 3087 if (cmd->sub_table != NULL && *p != '\0') {
250b8197 3088 return monitor_parse_command(mon, cmdp_start, cmdp, cmd->sub_table);
5f3d335f
WX
3089 }
3090
ae50212f
BD
3091 return cmd;
3092}
3093
3094/*
3095 * Parse arguments for @cmd.
3096 * If it can't be parsed, report to @mon, and return NULL.
3097 * Else, insert command arguments into a QDict, and return it.
3098 * Note: On success, caller has to free the QDict structure.
3099 */
3100
3101static QDict *monitor_parse_arguments(Monitor *mon,
3102 const char **endp,
3103 const mon_cmd_t *cmd)
3104{
3105 const char *typestr;
3106 char *key;
3107 int c;
3108 const char *p = *endp;
3109 char buf[1024];
3110 QDict *qdict = qdict_new();
3111
9307c4c1
FB
3112 /* parse the parameters */
3113 typestr = cmd->args_type;
9dc39cba 3114 for(;;) {
4d76d2ba
LC
3115 typestr = key_get_info(typestr, &key);
3116 if (!typestr)
9dc39cba 3117 break;
4d76d2ba 3118 c = *typestr;
9307c4c1
FB
3119 typestr++;
3120 switch(c) {
3121 case 'F':
81d0912d 3122 case 'B':
9307c4c1
FB
3123 case 's':
3124 {
3125 int ret;
3b46e624 3126
cd390083 3127 while (qemu_isspace(*p))
9307c4c1
FB
3128 p++;
3129 if (*typestr == '?') {
3130 typestr++;
3131 if (*p == '\0') {
3132 /* no optional string: NULL argument */
53773581 3133 break;
9307c4c1
FB
3134 }
3135 }
3136 ret = get_str(buf, sizeof(buf), &p);
3137 if (ret < 0) {
81d0912d
FB
3138 switch(c) {
3139 case 'F':
376253ec 3140 monitor_printf(mon, "%s: filename expected\n",
ae50212f 3141 cmd->name);
81d0912d
FB
3142 break;
3143 case 'B':
376253ec 3144 monitor_printf(mon, "%s: block device name expected\n",
ae50212f 3145 cmd->name);
81d0912d
FB
3146 break;
3147 default:
ae50212f 3148 monitor_printf(mon, "%s: string expected\n", cmd->name);
81d0912d
FB
3149 break;
3150 }
9307c4c1
FB
3151 goto fail;
3152 }
46f5ac20 3153 qdict_put_str(qdict, key, buf);
9307c4c1 3154 }
9dc39cba 3155 break;
361127df
MA
3156 case 'O':
3157 {
3158 QemuOptsList *opts_list;
3159 QemuOpts *opts;
3160
3161 opts_list = qemu_find_opts(key);
3162 if (!opts_list || opts_list->desc->name) {
3163 goto bad_type;
3164 }
3165 while (qemu_isspace(*p)) {
3166 p++;
3167 }
3168 if (!*p)
3169 break;
3170 if (get_str(buf, sizeof(buf), &p) < 0) {
3171 goto fail;
3172 }
70b94331 3173 opts = qemu_opts_parse_noisily(opts_list, buf, true);
361127df
MA
3174 if (!opts) {
3175 goto fail;
3176 }
3177 qemu_opts_to_qdict(opts, qdict);
3178 qemu_opts_del(opts);
3179 }
3180 break;
9307c4c1
FB
3181 case '/':
3182 {
3183 int count, format, size;
3b46e624 3184
cd390083 3185 while (qemu_isspace(*p))
9307c4c1
FB
3186 p++;
3187 if (*p == '/') {
3188 /* format found */
3189 p++;
3190 count = 1;
cd390083 3191 if (qemu_isdigit(*p)) {
9307c4c1 3192 count = 0;
cd390083 3193 while (qemu_isdigit(*p)) {
9307c4c1
FB
3194 count = count * 10 + (*p - '0');
3195 p++;
3196 }
3197 }
3198 size = -1;
3199 format = -1;
3200 for(;;) {
3201 switch(*p) {
3202 case 'o':
3203 case 'd':
3204 case 'u':
3205 case 'x':
3206 case 'i':
3207 case 'c':
3208 format = *p++;
3209 break;
3210 case 'b':
3211 size = 1;
3212 p++;
3213 break;
3214 case 'h':
3215 size = 2;
3216 p++;
3217 break;
3218 case 'w':
3219 size = 4;
3220 p++;
3221 break;
3222 case 'g':
3223 case 'L':
3224 size = 8;
3225 p++;
3226 break;
3227 default:
3228 goto next;
3229 }
3230 }
3231 next:
cd390083 3232 if (*p != '\0' && !qemu_isspace(*p)) {
376253ec
AL
3233 monitor_printf(mon, "invalid char in format: '%c'\n",
3234 *p);
9307c4c1
FB
3235 goto fail;
3236 }
9307c4c1
FB
3237 if (format < 0)
3238 format = default_fmt_format;
4c27ba27
FB
3239 if (format != 'i') {
3240 /* for 'i', not specifying a size gives -1 as size */
3241 if (size < 0)
3242 size = default_fmt_size;
e90f009b 3243 default_fmt_size = size;
4c27ba27 3244 }
9307c4c1
FB
3245 default_fmt_format = format;
3246 } else {
3247 count = 1;
3248 format = default_fmt_format;
4c27ba27
FB
3249 if (format != 'i') {
3250 size = default_fmt_size;
3251 } else {
3252 size = -1;
3253 }
9307c4c1 3254 }
46f5ac20
EB
3255 qdict_put_int(qdict, "count", count);
3256 qdict_put_int(qdict, "format", format);
3257 qdict_put_int(qdict, "size", size);
9307c4c1 3258 }
9dc39cba 3259 break;
9307c4c1 3260 case 'i':
92a31b1f 3261 case 'l':
b6e098d7 3262 case 'M':
9307c4c1 3263 {
c2efc95d 3264 int64_t val;
7743e588 3265
cd390083 3266 while (qemu_isspace(*p))
9307c4c1 3267 p++;
3440557b 3268 if (*typestr == '?' || *typestr == '.') {
3440557b 3269 if (*typestr == '?') {
53773581
LC
3270 if (*p == '\0') {
3271 typestr++;
3272 break;
3273 }
3440557b
FB
3274 } else {
3275 if (*p == '.') {
3276 p++;
cd390083 3277 while (qemu_isspace(*p))
3440557b 3278 p++;
3440557b 3279 } else {
53773581
LC
3280 typestr++;
3281 break;
3440557b
FB
3282 }
3283 }
13224a87 3284 typestr++;
9307c4c1 3285 }
376253ec 3286 if (get_expr(mon, &val, &p))
9307c4c1 3287 goto fail;
675ebef9
LC
3288 /* Check if 'i' is greater than 32-bit */
3289 if ((c == 'i') && ((val >> 32) & 0xffffffff)) {
ae50212f 3290 monitor_printf(mon, "\'%s\' has failed: ", cmd->name);
675ebef9
LC
3291 monitor_printf(mon, "integer is for 32-bit values\n");
3292 goto fail;
b6e098d7 3293 } else if (c == 'M') {
91162849
LC
3294 if (val < 0) {
3295 monitor_printf(mon, "enter a positive value\n");
3296 goto fail;
3297 }
8ec338ac 3298 val *= MiB;
675ebef9 3299 }
46f5ac20 3300 qdict_put_int(qdict, key, val);
9307c4c1
FB
3301 }
3302 break;
dbc0c67f
JS
3303 case 'o':
3304 {
f17fd4fd 3305 int ret;
f46bfdbf 3306 uint64_t val;
dbc0c67f
JS
3307 char *end;
3308
3309 while (qemu_isspace(*p)) {
3310 p++;
3311 }
3312 if (*typestr == '?') {
3313 typestr++;
3314 if (*p == '\0') {
3315 break;
3316 }
3317 }
f17fd4fd 3318 ret = qemu_strtosz_MiB(p, &end, &val);
f46bfdbf 3319 if (ret < 0 || val > INT64_MAX) {
dbc0c67f
JS
3320 monitor_printf(mon, "invalid size\n");
3321 goto fail;
3322 }
46f5ac20 3323 qdict_put_int(qdict, key, val);
dbc0c67f
JS
3324 p = end;
3325 }
3326 break;
fccfb11e 3327 case 'T':
3350a4dd
MA
3328 {
3329 double val;
3330
3331 while (qemu_isspace(*p))
3332 p++;
3333 if (*typestr == '?') {
3334 typestr++;
3335 if (*p == '\0') {
3336 break;
3337 }
3338 }
3339 if (get_double(mon, &val, &p) < 0) {
3340 goto fail;
3341 }
07de3e60 3342 if (p[0] && p[1] == 's') {
fccfb11e
MA
3343 switch (*p) {
3344 case 'm':
3345 val /= 1e3; p += 2; break;
3346 case 'u':
3347 val /= 1e6; p += 2; break;
3348 case 'n':
3349 val /= 1e9; p += 2; break;
3350 }
3351 }
3350a4dd
MA
3352 if (*p && !qemu_isspace(*p)) {
3353 monitor_printf(mon, "Unknown unit suffix\n");
3354 goto fail;
3355 }
01b2ffce 3356 qdict_put(qdict, key, qnum_from_double(val));
3350a4dd
MA
3357 }
3358 break;
942cd1f2
MA
3359 case 'b':
3360 {
3361 const char *beg;
fc48ffc3 3362 bool val;
942cd1f2
MA
3363
3364 while (qemu_isspace(*p)) {
3365 p++;
3366 }
3367 beg = p;
3368 while (qemu_isgraph(*p)) {
3369 p++;
3370 }
3371 if (p - beg == 2 && !memcmp(beg, "on", p - beg)) {
fc48ffc3 3372 val = true;
942cd1f2 3373 } else if (p - beg == 3 && !memcmp(beg, "off", p - beg)) {
fc48ffc3 3374 val = false;
942cd1f2
MA
3375 } else {
3376 monitor_printf(mon, "Expected 'on' or 'off'\n");
3377 goto fail;
3378 }
46f5ac20 3379 qdict_put_bool(qdict, key, val);
942cd1f2
MA
3380 }
3381 break;
9307c4c1
FB
3382 case '-':
3383 {
fbc3d96c 3384 const char *tmp = p;
eb159d13 3385 int skip_key = 0;
9307c4c1 3386 /* option */
3b46e624 3387
9307c4c1
FB
3388 c = *typestr++;
3389 if (c == '\0')
3390 goto bad_type;
cd390083 3391 while (qemu_isspace(*p))
9307c4c1 3392 p++;
9307c4c1
FB
3393 if (*p == '-') {
3394 p++;
fbc3d96c
LS
3395 if(c != *p) {
3396 if(!is_valid_option(p, typestr)) {
3397
3398 monitor_printf(mon, "%s: unsupported option -%c\n",
ae50212f 3399 cmd->name, *p);
fbc3d96c
LS
3400 goto fail;
3401 } else {
3402 skip_key = 1;
3403 }
3404 }
3405 if(skip_key) {
3406 p = tmp;
3407 } else {
eb159d13 3408 /* has option */
fbc3d96c 3409 p++;
46f5ac20 3410 qdict_put_bool(qdict, key, true);
9307c4c1 3411 }
9307c4c1 3412 }
9307c4c1
FB
3413 }
3414 break;
129be006
WX
3415 case 'S':
3416 {
3417 /* package all remaining string */
3418 int len;
3419
3420 while (qemu_isspace(*p)) {
3421 p++;
3422 }
3423 if (*typestr == '?') {
3424 typestr++;
3425 if (*p == '\0') {
3426 /* no remaining string: NULL argument */
3427 break;
3428 }
3429 }
3430 len = strlen(p);
3431 if (len <= 0) {
3432 monitor_printf(mon, "%s: string expected\n",
ae50212f 3433 cmd->name);
e549d2aa 3434 goto fail;
129be006 3435 }
46f5ac20 3436 qdict_put_str(qdict, key, p);
129be006
WX
3437 p += len;
3438 }
3439 break;
9307c4c1
FB
3440 default:
3441 bad_type:
ae50212f 3442 monitor_printf(mon, "%s: unknown type '%c'\n", cmd->name, c);
9307c4c1
FB
3443 goto fail;
3444 }
7267c094 3445 g_free(key);
4d76d2ba 3446 key = NULL;
9dc39cba 3447 }
9307c4c1 3448 /* check that all arguments were parsed */
cd390083 3449 while (qemu_isspace(*p))
9307c4c1
FB
3450 p++;
3451 if (*p != '\0') {
376253ec 3452 monitor_printf(mon, "%s: extraneous characters at the end of line\n",
ae50212f 3453 cmd->name);
9307c4c1 3454 goto fail;
9dc39cba 3455 }
9307c4c1 3456
ae50212f 3457 return qdict;
ac7531ec 3458
55f81d96 3459fail:
cb3e7f08 3460 qobject_unref(qdict);
7267c094 3461 g_free(key);
55f81d96
LC
3462 return NULL;
3463}
3464
7ef6cf63 3465static void handle_hmp_command(Monitor *mon, const char *cmdline)
55f81d96 3466{
55f81d96 3467 QDict *qdict;
c227f099 3468 const mon_cmd_t *cmd;
317c52cc 3469 const char *cmd_start = cmdline;
55f81d96 3470
79cad8b4
SH
3471 trace_handle_hmp_command(mon, cmdline);
3472
250b8197 3473 cmd = monitor_parse_command(mon, cmdline, &cmdline, mon->cmd_table);
ae50212f
BD
3474 if (!cmd) {
3475 return;
3476 }
55f81d96 3477
ae50212f
BD
3478 qdict = monitor_parse_arguments(mon, &cmdline, cmd);
3479 if (!qdict) {
317c52cc
CW
3480 while (cmdline > cmd_start && qemu_isspace(cmdline[-1])) {
3481 cmdline--;
3482 }
3483 monitor_printf(mon, "Try \"help %.*s\" for more information\n",
3484 (int)(cmdline - cmd_start), cmd_start);
ae50212f 3485 return;
55f81d96
LC
3486 }
3487
2b9e3576 3488 cmd->cmd(mon, qdict);
cb3e7f08 3489 qobject_unref(qdict);
9dc39cba
FB
3490}
3491
cd5c6bba 3492static void cmd_completion(Monitor *mon, const char *name, const char *list)
81d0912d
FB
3493{
3494 const char *p, *pstart;
3495 char cmd[128];
3496 int len;
3497
3498 p = list;
3499 for(;;) {
3500 pstart = p;
5c99fa37 3501 p = qemu_strchrnul(p, '|');
81d0912d
FB
3502 len = p - pstart;
3503 if (len > sizeof(cmd) - 2)
3504 len = sizeof(cmd) - 2;
3505 memcpy(cmd, pstart, len);
3506 cmd[len] = '\0';
3507 if (name[0] == '\0' || !strncmp(name, cmd, strlen(name))) {
cd5c6bba 3508 readline_add_completion(mon->rs, cmd);
81d0912d
FB
3509 }
3510 if (*p == '\0')
3511 break;
3512 p++;
3513 }
3514}
3515
cb8f68b1 3516static void file_completion(Monitor *mon, const char *input)
81d0912d
FB
3517{
3518 DIR *ffs;
3519 struct dirent *d;
3520 char path[1024];
3521 char file[1024], file_prefix[1024];
3522 int input_path_len;
3523 const char *p;
3524
5fafdf24 3525 p = strrchr(input, '/');
81d0912d
FB
3526 if (!p) {
3527 input_path_len = 0;
3528 pstrcpy(file_prefix, sizeof(file_prefix), input);
363a37d5 3529 pstrcpy(path, sizeof(path), ".");
81d0912d
FB
3530 } else {
3531 input_path_len = p - input + 1;
3532 memcpy(path, input, input_path_len);
3533 if (input_path_len > sizeof(path) - 1)
3534 input_path_len = sizeof(path) - 1;
3535 path[input_path_len] = '\0';
3536 pstrcpy(file_prefix, sizeof(file_prefix), p + 1);
3537 }
19f2db5c 3538
81d0912d
FB
3539 ffs = opendir(path);
3540 if (!ffs)
3541 return;
3542 for(;;) {
3543 struct stat sb;
3544 d = readdir(ffs);
3545 if (!d)
3546 break;
46c7fc18
KK
3547
3548 if (strcmp(d->d_name, ".") == 0 || strcmp(d->d_name, "..") == 0) {
3549 continue;
3550 }
3551
81d0912d
FB
3552 if (strstart(d->d_name, file_prefix, NULL)) {
3553 memcpy(file, input, input_path_len);
363a37d5
BS
3554 if (input_path_len < sizeof(file))
3555 pstrcpy(file + input_path_len, sizeof(file) - input_path_len,
3556 d->d_name);
81d0912d
FB
3557 /* stat the file to find out if it's a directory.
3558 * In that case add a slash to speed up typing long paths
3559 */
c951d9a6 3560 if (stat(file, &sb) == 0 && S_ISDIR(sb.st_mode)) {
363a37d5 3561 pstrcat(file, sizeof(file), "/");
c951d9a6 3562 }
cb8f68b1 3563 readline_add_completion(mon->rs, file);
81d0912d
FB
3564 }
3565 }
3566 closedir(ffs);
3567}
3568
4d76d2ba
LC
3569static const char *next_arg_type(const char *typestr)
3570{
3571 const char *p = strchr(typestr, ':');
3572 return (p != NULL ? ++p : typestr);
3573}
3574
40d19394
HB
3575static void add_completion_option(ReadLineState *rs, const char *str,
3576 const char *option)
3577{
3578 if (!str || !option) {
3579 return;
3580 }
3581 if (!strncmp(option, str, strlen(str))) {
3582 readline_add_completion(rs, option);
3583 }
3584}
3585
13e315da
HB
3586void chardev_add_completion(ReadLineState *rs, int nb_args, const char *str)
3587{
3588 size_t len;
3589 ChardevBackendInfoList *list, *start;
3590
3591 if (nb_args != 2) {
3592 return;
3593 }
3594 len = strlen(str);
3595 readline_set_completion_index(rs, len);
3596
3597 start = list = qmp_query_chardev_backends(NULL);
3598 while (list) {
3599 const char *chr_name = list->value->name;
3600
3601 if (!strncmp(chr_name, str, len)) {
3602 readline_add_completion(rs, chr_name);
3603 }
3604 list = list->next;
3605 }
3606 qapi_free_ChardevBackendInfoList(start);
3607}
3608
b162b49a
HB
3609void netdev_add_completion(ReadLineState *rs, int nb_args, const char *str)
3610{
3611 size_t len;
3612 int i;
3613
3614 if (nb_args != 2) {
3615 return;
3616 }
3617 len = strlen(str);
3618 readline_set_completion_index(rs, len);
1c236ba5 3619 for (i = 0; i < NET_CLIENT_DRIVER__MAX; i++) {
977c736f 3620 add_completion_option(rs, str, NetClientDriver_str(i));
b162b49a
HB
3621 }
3622}
3623
2da1b3ab 3624void device_add_completion(ReadLineState *rs, int nb_args, const char *str)
992d3e64
HB
3625{
3626 GSList *list, *elt;
3627 size_t len;
3628
2da1b3ab
HB
3629 if (nb_args != 2) {
3630 return;
3631 }
3632
992d3e64
HB
3633 len = strlen(str);
3634 readline_set_completion_index(rs, len);
3635 list = elt = object_class_get_list(TYPE_DEVICE, false);
3636 while (elt) {
3637 const char *name;
3638 DeviceClass *dc = OBJECT_CLASS_CHECK(DeviceClass, elt->data,
3639 TYPE_DEVICE);
3640 name = object_class_get_name(OBJECT_CLASS(dc));
2da1b3ab 3641
e90f2a8c 3642 if (dc->user_creatable
2da1b3ab 3643 && !strncmp(name, str, len)) {
992d3e64
HB
3644 readline_add_completion(rs, name);
3645 }
3646 elt = elt->next;
3647 }
3648 g_slist_free(list);
3649}
3650
bfa40f77 3651void object_add_completion(ReadLineState *rs, int nb_args, const char *str)
1094fd3a
HB
3652{
3653 GSList *list, *elt;
3654 size_t len;
3655
bfa40f77
HB
3656 if (nb_args != 2) {
3657 return;
3658 }
3659
1094fd3a
HB
3660 len = strlen(str);
3661 readline_set_completion_index(rs, len);
3662 list = elt = object_class_get_list(TYPE_USER_CREATABLE, false);
3663 while (elt) {
3664 const char *name;
3665
3666 name = object_class_get_name(OBJECT_CLASS(elt->data));
3667 if (!strncmp(name, str, len) && strcmp(name, TYPE_USER_CREATABLE)) {
3668 readline_add_completion(rs, name);
3669 }
3670 elt = elt->next;
3671 }
3672 g_slist_free(list);
3673}
3674
6a1fa9f5
ZG
3675static void peripheral_device_del_completion(ReadLineState *rs,
3676 const char *str, size_t len)
3677{
4cae4d5a
MA
3678 Object *peripheral = container_get(qdev_get_machine(), "/peripheral");
3679 GSList *list, *item;
6a1fa9f5 3680
4cae4d5a
MA
3681 list = qdev_build_hotpluggable_device_list(peripheral);
3682 if (!list) {
6a1fa9f5
ZG
3683 return;
3684 }
3685
6a1fa9f5
ZG
3686 for (item = list; item; item = g_slist_next(item)) {
3687 DeviceState *dev = item->data;
3688
3689 if (dev->id && !strncmp(str, dev->id, len)) {
3690 readline_add_completion(rs, dev->id);
3691 }
3692 }
3693
3694 g_slist_free(list);
3695}
3696
6297d9a2
HB
3697void chardev_remove_completion(ReadLineState *rs, int nb_args, const char *str)
3698{
3699 size_t len;
3700 ChardevInfoList *list, *start;
3701
3702 if (nb_args != 2) {
3703 return;
3704 }
3705 len = strlen(str);
3706 readline_set_completion_index(rs, len);
3707
3708 start = list = qmp_query_chardev(NULL);
3709 while (list) {
3710 ChardevInfo *chr = list->value;
3711
3712 if (!strncmp(chr->label, str, len)) {
3713 readline_add_completion(rs, chr->label);
3714 }
3715 list = list->next;
3716 }
3717 qapi_free_ChardevInfoList(start);
3718}
3719
8e597779
HB
3720static void ringbuf_completion(ReadLineState *rs, const char *str)
3721{
3722 size_t len;
3723 ChardevInfoList *list, *start;
3724
3725 len = strlen(str);
3726 readline_set_completion_index(rs, len);
3727
3728 start = list = qmp_query_chardev(NULL);
3729 while (list) {
3730 ChardevInfo *chr_info = list->value;
3731
3732 if (!strncmp(chr_info->label, str, len)) {
0ec7b3e7 3733 Chardev *chr = qemu_chr_find(chr_info->label);
777357d7 3734 if (chr && CHARDEV_IS_RINGBUF(chr)) {
8e597779
HB
3735 readline_add_completion(rs, chr_info->label);
3736 }
3737 }
3738 list = list->next;
3739 }
3740 qapi_free_ChardevInfoList(start);
3741}
3742
8e597779
HB
3743void ringbuf_write_completion(ReadLineState *rs, int nb_args, const char *str)
3744{
3745 if (nb_args != 2) {
3746 return;
3747 }
3748 ringbuf_completion(rs, str);
3749}
3750
2da1b3ab
HB
3751void device_del_completion(ReadLineState *rs, int nb_args, const char *str)
3752{
3753 size_t len;
3754
3755 if (nb_args != 2) {
3756 return;
3757 }
3758
3759 len = strlen(str);
3760 readline_set_completion_index(rs, len);
6a1fa9f5 3761 peripheral_device_del_completion(rs, str, len);
2da1b3ab
HB
3762}
3763
bfa40f77 3764void object_del_completion(ReadLineState *rs, int nb_args, const char *str)
b48fa074
HB
3765{
3766 ObjectPropertyInfoList *list, *start;
3767 size_t len;
3768
bfa40f77
HB
3769 if (nb_args != 2) {
3770 return;
3771 }
b48fa074
HB
3772 len = strlen(str);
3773 readline_set_completion_index(rs, len);
3774
3775 start = list = qmp_qom_list("/objects", NULL);
3776 while (list) {
3777 ObjectPropertyInfo *info = list->value;
3778
3779 if (!strncmp(info->type, "child<", 5)
3780 && !strncmp(info->name, str, len)) {
3781 readline_add_completion(rs, info->name);
3782 }
3783 list = list->next;
3784 }
3785 qapi_free_ObjectPropertyInfoList(start);
3786}
3787
29136cd8
HB
3788void sendkey_completion(ReadLineState *rs, int nb_args, const char *str)
3789{
3790 int i;
3791 char *sep;
3792 size_t len;
3793
3794 if (nb_args != 2) {
3795 return;
3796 }
3797 sep = strrchr(str, '-');
3798 if (sep) {
3799 str = sep + 1;
3800 }
3801 len = strlen(str);
3802 readline_set_completion_index(rs, len);
7fb1cf16 3803 for (i = 0; i < Q_KEY_CODE__MAX; i++) {
977c736f
MA
3804 if (!strncmp(str, QKeyCode_str(i), len)) {
3805 readline_add_completion(rs, QKeyCode_str(i));
29136cd8
HB
3806 }
3807 }
3808}
3809
40d19394
HB
3810void set_link_completion(ReadLineState *rs, int nb_args, const char *str)
3811{
3812 size_t len;
3813
3814 len = strlen(str);
3815 readline_set_completion_index(rs, len);
3816 if (nb_args == 2) {
eaed483c 3817 NetClientState *ncs[MAX_QUEUE_NUM];
40d19394
HB
3818 int count, i;
3819 count = qemu_find_net_clients_except(NULL, ncs,
f394b2e2 3820 NET_CLIENT_DRIVER_NONE,
eaed483c 3821 MAX_QUEUE_NUM);
bcfa4d60 3822 for (i = 0; i < MIN(count, MAX_QUEUE_NUM); i++) {
40d19394
HB
3823 const char *name = ncs[i]->name;
3824 if (!strncmp(str, name, len)) {
3825 readline_add_completion(rs, name);
3826 }
3827 }
3828 } else if (nb_args == 3) {
3829 add_completion_option(rs, str, "on");
3830 add_completion_option(rs, str, "off");
3831 }
3832}
3833
11b389f2
HB
3834void netdev_del_completion(ReadLineState *rs, int nb_args, const char *str)
3835{
3836 int len, count, i;
eaed483c 3837 NetClientState *ncs[MAX_QUEUE_NUM];
11b389f2
HB
3838
3839 if (nb_args != 2) {
3840 return;
3841 }
3842
3843 len = strlen(str);
3844 readline_set_completion_index(rs, len);
f394b2e2 3845 count = qemu_find_net_clients_except(NULL, ncs, NET_CLIENT_DRIVER_NIC,
eaed483c 3846 MAX_QUEUE_NUM);
bcfa4d60 3847 for (i = 0; i < MIN(count, MAX_QUEUE_NUM); i++) {
11b389f2
HB
3848 QemuOpts *opts;
3849 const char *name = ncs[i]->name;
3850 if (strncmp(str, name, len)) {
3851 continue;
3852 }
3853 opts = qemu_opts_find(qemu_find_opts_err("netdev", NULL), name);
3854 if (opts) {
3855 readline_add_completion(rs, name);
3856 }
3857 }
3858}
3859
bd71211d
LV
3860void info_trace_events_completion(ReadLineState *rs, int nb_args, const char *str)
3861{
3862 size_t len;
3863
3864 len = strlen(str);
3865 readline_set_completion_index(rs, len);
3866 if (nb_args == 2) {
0d4e995c
DB
3867 TraceEventIter iter;
3868 TraceEvent *ev;
3869 char *pattern = g_strdup_printf("%s*", str);
3870 trace_event_iter_init(&iter, pattern);
3871 while ((ev = trace_event_iter_next(&iter)) != NULL) {
3872 readline_add_completion(rs, trace_event_get_name(ev));
bd71211d 3873 }
0d4e995c 3874 g_free(pattern);
bd71211d
LV
3875 }
3876}
3877
987bd270
DDAG
3878void trace_event_completion(ReadLineState *rs, int nb_args, const char *str)
3879{
3880 size_t len;
3881
3882 len = strlen(str);
3883 readline_set_completion_index(rs, len);
3884 if (nb_args == 2) {
0d4e995c
DB
3885 TraceEventIter iter;
3886 TraceEvent *ev;
3887 char *pattern = g_strdup_printf("%s*", str);
3888 trace_event_iter_init(&iter, pattern);
3889 while ((ev = trace_event_iter_next(&iter)) != NULL) {
3890 readline_add_completion(rs, trace_event_get_name(ev));
3891 }
3892 g_free(pattern);
987bd270
DDAG
3893 } else if (nb_args == 3) {
3894 add_completion_option(rs, str, "on");
3895 add_completion_option(rs, str, "off");
3896 }
3897}
3898
d0ece345
HB
3899void watchdog_action_completion(ReadLineState *rs, int nb_args, const char *str)
3900{
4bb08af3
HB
3901 int i;
3902
d0ece345
HB
3903 if (nb_args != 2) {
3904 return;
3905 }
3906 readline_set_completion_index(rs, strlen(str));
14d53b4f
MP
3907 for (i = 0; i < WATCHDOG_ACTION__MAX; i++) {
3908 add_completion_option(rs, str, WatchdogAction_str(i));
4bb08af3 3909 }
d0ece345
HB
3910}
3911
c68a0409
HB
3912void migrate_set_capability_completion(ReadLineState *rs, int nb_args,
3913 const char *str)
3914{
3915 size_t len;
3916
3917 len = strlen(str);
3918 readline_set_completion_index(rs, len);
3919 if (nb_args == 2) {
3920 int i;
7fb1cf16 3921 for (i = 0; i < MIGRATION_CAPABILITY__MAX; i++) {
977c736f 3922 const char *name = MigrationCapability_str(i);
c68a0409
HB
3923 if (!strncmp(str, name, len)) {
3924 readline_add_completion(rs, name);
3925 }
3926 }
3927 } else if (nb_args == 3) {
3928 add_completion_option(rs, str, "on");
3929 add_completion_option(rs, str, "off");
3930 }
3931}
3932
50e9a629
LL
3933void migrate_set_parameter_completion(ReadLineState *rs, int nb_args,
3934 const char *str)
3935{
3936 size_t len;
3937
3938 len = strlen(str);
3939 readline_set_completion_index(rs, len);
3940 if (nb_args == 2) {
3941 int i;
7fb1cf16 3942 for (i = 0; i < MIGRATION_PARAMETER__MAX; i++) {
977c736f 3943 const char *name = MigrationParameter_str(i);
50e9a629
LL
3944 if (!strncmp(str, name, len)) {
3945 readline_add_completion(rs, name);
3946 }
3947 }
3948 }
3949}
3950
b21631f3
HB
3951static void vm_completion(ReadLineState *rs, const char *str)
3952{
3953 size_t len;
7c8eece4 3954 BlockDriverState *bs;
88be7b4b 3955 BdrvNextIterator it;
b21631f3
HB
3956
3957 len = strlen(str);
3958 readline_set_completion_index(rs, len);
7c8eece4 3959
88be7b4b 3960 for (bs = bdrv_first(&it); bs; bs = bdrv_next(&it)) {
b21631f3 3961 SnapshotInfoList *snapshots, *snapshot;
6bf1faa8
DL
3962 AioContext *ctx = bdrv_get_aio_context(bs);
3963 bool ok = false;
b21631f3 3964
6bf1faa8
DL
3965 aio_context_acquire(ctx);
3966 if (bdrv_can_snapshot(bs)) {
3967 ok = bdrv_query_snapshot_info_list(bs, &snapshots, NULL) == 0;
b21631f3 3968 }
6bf1faa8
DL
3969 aio_context_release(ctx);
3970 if (!ok) {
b21631f3
HB
3971 continue;
3972 }
6bf1faa8 3973
b21631f3
HB
3974 snapshot = snapshots;
3975 while (snapshot) {
3976 char *completion = snapshot->value->name;
3977 if (!strncmp(str, completion, len)) {
3978 readline_add_completion(rs, completion);
3979 }
3980 completion = snapshot->value->id;
3981 if (!strncmp(str, completion, len)) {
3982 readline_add_completion(rs, completion);
3983 }
3984 snapshot = snapshot->next;
3985 }
3986 qapi_free_SnapshotInfoList(snapshots);
3987 }
3988
3989}
3990
3991void delvm_completion(ReadLineState *rs, int nb_args, const char *str)
3992{
3993 if (nb_args == 2) {
3994 vm_completion(rs, str);
3995 }
3996}
3997
3998void loadvm_completion(ReadLineState *rs, int nb_args, const char *str)
3999{
4000 if (nb_args == 2) {
4001 vm_completion(rs, str);
4002 }
4003}
4004
c35b6400
WX
4005static void monitor_find_completion_by_table(Monitor *mon,
4006 const mon_cmd_t *cmd_table,
4007 char **args,
4008 int nb_args)
81d0912d
FB
4009{
4010 const char *cmdname;
c35b6400 4011 int i;
bf67f1c0 4012 const char *ptype, *old_ptype, *str, *name;
c227f099 4013 const mon_cmd_t *cmd;
da27a00e 4014 BlockBackend *blk = NULL;
81d0912d 4015
81d0912d
FB
4016 if (nb_args <= 1) {
4017 /* command completion */
4018 if (nb_args == 0)
4019 cmdname = "";
4020 else
4021 cmdname = args[0];
d2674b2c 4022 readline_set_completion_index(mon->rs, strlen(cmdname));
c35b6400 4023 for (cmd = cmd_table; cmd->name != NULL; cmd++) {
6d9f7839
DDAG
4024 if (!runstate_check(RUN_STATE_PRECONFIG) ||
4025 cmd_can_preconfig(cmd)) {
4026 cmd_completion(mon, cmdname, cmd->name);
4027 }
81d0912d
FB
4028 }
4029 } else {
4030 /* find the command */
c35b6400 4031 for (cmd = cmd_table; cmd->name != NULL; cmd++) {
6d9f7839
DDAG
4032 if (compare_cmd(args[0], cmd->name) &&
4033 (!runstate_check(RUN_STATE_PRECONFIG) ||
4034 cmd_can_preconfig(cmd))) {
03a63484
JK
4035 break;
4036 }
81d0912d 4037 }
03a63484 4038 if (!cmd->name) {
c35b6400 4039 return;
03a63484
JK
4040 }
4041
d903a779
WX
4042 if (cmd->sub_table) {
4043 /* do the job again */
e7ae771f
SW
4044 monitor_find_completion_by_table(mon, cmd->sub_table,
4045 &args[1], nb_args - 1);
4046 return;
d903a779 4047 }
bfa40f77 4048 if (cmd->command_completion) {
e7ae771f
SW
4049 cmd->command_completion(mon->rs, nb_args, args[nb_args - 1]);
4050 return;
bfa40f77 4051 }
d903a779 4052
4d76d2ba 4053 ptype = next_arg_type(cmd->args_type);
81d0912d
FB
4054 for(i = 0; i < nb_args - 2; i++) {
4055 if (*ptype != '\0') {
4d76d2ba 4056 ptype = next_arg_type(ptype);
81d0912d 4057 while (*ptype == '?')
4d76d2ba 4058 ptype = next_arg_type(ptype);
81d0912d
FB
4059 }
4060 }
4061 str = args[nb_args - 1];
bf67f1c0
DDAG
4062 old_ptype = NULL;
4063 while (*ptype == '-' && old_ptype != ptype) {
4064 old_ptype = ptype;
3b6dbf27 4065 ptype = next_arg_type(ptype);
2a1704a7 4066 }
81d0912d
FB
4067 switch(*ptype) {
4068 case 'F':
4069 /* file completion */
d2674b2c 4070 readline_set_completion_index(mon->rs, strlen(str));
cb8f68b1 4071 file_completion(mon, str);
81d0912d
FB
4072 break;
4073 case 'B':
4074 /* block device name completion */
599a926a 4075 readline_set_completion_index(mon->rs, strlen(str));
da27a00e
HR
4076 while ((blk = blk_next(blk)) != NULL) {
4077 name = blk_name(blk);
fea68bb6
MA
4078 if (str[0] == '\0' ||
4079 !strncmp(name, str, strlen(str))) {
4080 readline_add_completion(mon->rs, name);
4081 }
4082 }
81d0912d 4083 break;
7fe48483 4084 case 's':
129be006 4085 case 'S':
29136cd8 4086 if (!strcmp(cmd->name, "help|?")) {
7ca0e061
WX
4087 monitor_find_completion_by_table(mon, cmd_table,
4088 &args[1], nb_args - 1);
7fe48483
FB
4089 }
4090 break;
81d0912d
FB
4091 default:
4092 break;
4093 }
4094 }
c35b6400
WX
4095}
4096
c60bf339 4097static void monitor_find_completion(void *opaque,
c35b6400
WX
4098 const char *cmdline)
4099{
c60bf339 4100 Monitor *mon = opaque;
c35b6400
WX
4101 char *args[MAX_ARGS];
4102 int nb_args, len;
4103
4104 /* 1. parse the cmdline */
4105 if (parse_cmdline(cmdline, &nb_args, args) < 0) {
4106 return;
4107 }
c35b6400
WX
4108
4109 /* if the line ends with a space, it means we want to complete the
4110 next arg */
4111 len = strlen(cmdline);
4112 if (len > 0 && qemu_isspace(cmdline[len - 1])) {
4113 if (nb_args >= MAX_ARGS) {
4114 goto cleanup;
4115 }
4116 args[nb_args++] = g_strdup("");
4117 }
4118
4119 /* 2. auto complete according to args */
4120 monitor_find_completion_by_table(mon, mon->cmd_table, args, nb_args);
03a63484
JK
4121
4122cleanup:
dcc70cdf 4123 free_cmdline_args(args, nb_args);
81d0912d
FB
4124}
4125
731b0364 4126static int monitor_can_read(void *opaque)
9dc39cba 4127{
731b0364
AL
4128 Monitor *mon = opaque;
4129
df152fb9 4130 return !atomic_mb_read(&mon->suspend_cnt);
9dc39cba
FB
4131}
4132
546aa566 4133/*
7cb2123f
MA
4134 * Emit QMP response @rsp with ID @id to @mon.
4135 * Null @rsp can only happen for commands with QCO_NO_SUCCESS_RESP.
4136 * Nothing is emitted then.
546aa566 4137 */
7cb2123f 4138static void monitor_qmp_respond(Monitor *mon, QDict *rsp, QObject *id)
546aa566 4139{
546aa566
PX
4140 if (rsp) {
4141 if (id) {
d43b1694 4142 qdict_put_obj(rsp, "id", qobject_ref(id));
546aa566
PX
4143 }
4144
65e3fe67 4145 qmp_queue_response(mon, rsp);
546aa566 4146 }
546aa566
PX
4147}
4148
b2731456 4149static void monitor_qmp_dispatch(Monitor *mon, QObject *req, QObject *id)
5fa737a4 4150{
b2731456 4151 Monitor *old_mon;
d43b1694 4152 QDict *rsp;
69240fe6 4153 QDict *error;
b097efc0 4154
227a0755
PX
4155 old_mon = cur_mon;
4156 cur_mon = mon;
4157
674ed722 4158 rsp = qmp_dispatch(mon->qmp.commands, req, qmp_oob_enabled(mon));
5fa737a4 4159
227a0755
PX
4160 cur_mon = old_mon;
4161
69240fe6 4162 if (mon->qmp.commands == &qmp_cap_negotiation_commands) {
d43b1694 4163 error = qdict_get_qdict(rsp, "error");
69240fe6
MA
4164 if (error
4165 && !g_strcmp0(qdict_get_try_str(error, "class"),
4166 QapiErrorClass_str(ERROR_CLASS_COMMAND_NOT_FOUND))) {
4167 /* Provide a more useful error message */
4168 qdict_del(error, "desc");
4169 qdict_put_str(error, "desc", "Expecting capabilities negotiation"
4170 " with 'qmp_capabilities'");
4171 }
71da4667 4172 }
5fa737a4 4173
7cb2123f
MA
4174 monitor_qmp_respond(mon, rsp, id);
4175 qobject_unref(rsp);
5fa737a4
LC
4176}
4177
71da4667 4178/*
774a6b67
MA
4179 * Pop a QMP request from a monitor request queue.
4180 * Return the request, or NULL all request queues are empty.
71da4667
PX
4181 * We are using round-robin fashion to pop the request, to avoid
4182 * processing commands only on a very busy monitor. To achieve that,
4183 * when we process one request on a specific monitor, we put that
4184 * monitor to the end of mon_list queue.
4185 */
40687eb7 4186static QMPRequest *monitor_qmp_requests_pop_any(void)
71da4667
PX
4187{
4188 QMPRequest *req_obj = NULL;
4189 Monitor *mon;
4190
4191 qemu_mutex_lock(&monitor_lock);
4192
4193 QTAILQ_FOREACH(mon, &mon_list, entry) {
4194 qemu_mutex_lock(&mon->qmp.qmp_queue_lock);
4195 req_obj = g_queue_pop_head(mon->qmp.qmp_requests);
4196 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
4197 if (req_obj) {
4198 break;
4199 }
4200 }
4201
4202 if (req_obj) {
4203 /*
4204 * We found one request on the monitor. Degrade this monitor's
4205 * priority to lowest by re-inserting it to end of queue.
4206 */
4207 QTAILQ_REMOVE(&mon_list, mon, entry);
4208 QTAILQ_INSERT_TAIL(&mon_list, mon, entry);
4209 }
4210
4211 qemu_mutex_unlock(&monitor_lock);
4212
4213 return req_obj;
4214}
4215
4216static void monitor_qmp_bh_dispatcher(void *data)
4217{
40687eb7 4218 QMPRequest *req_obj = monitor_qmp_requests_pop_any();
7cb2123f 4219 QDict *rsp;
71da4667 4220
b2731456
MA
4221 if (!req_obj) {
4222 return;
71da4667 4223 }
b2731456 4224
1cc37471 4225 if (req_obj->req) {
cf869d53 4226 trace_monitor_qmp_cmd_in_band(qobject_get_try_str(req_obj->id) ?: "");
1cc37471
MA
4227 monitor_qmp_dispatch(req_obj->mon, req_obj->req, req_obj->id);
4228 } else {
4229 assert(req_obj->err);
7cb2123f 4230 rsp = qmp_error_response(req_obj->err);
42eab8db 4231 req_obj->err = NULL;
7cb2123f
MA
4232 monitor_qmp_respond(req_obj->mon, rsp, NULL);
4233 qobject_unref(rsp);
1cc37471
MA
4234 }
4235
b2731456
MA
4236 if (req_obj->need_resume) {
4237 /* Pairs with the monitor_suspend() in handle_qmp_command() */
4238 monitor_resume(req_obj->mon);
71da4667 4239 }
b2731456
MA
4240 qmp_request_free(req_obj);
4241
4242 /* Reschedule instead of looping so the main loop stays responsive */
cab5ad86 4243 qemu_bh_schedule(qmp_dispatcher_bh);
71da4667
PX
4244}
4245
bf1e7301
PX
4246#define QMP_REQ_QUEUE_LEN_MAX (8)
4247
71da4667
PX
4248static void handle_qmp_command(JSONMessageParser *parser, GQueue *tokens)
4249{
4250 QObject *req, *id = NULL;
0fa39d0b 4251 QDict *qdict;
71da4667
PX
4252 MonitorQMP *mon_qmp = container_of(parser, MonitorQMP, parser);
4253 Monitor *mon = container_of(mon_qmp, Monitor, qmp);
4254 Error *err = NULL;
4255 QMPRequest *req_obj;
4256
4257 req = json_parser_parse_err(tokens, NULL, &err);
4258 if (!req && !err) {
4259 /* json_parser_parse_err() sucks: can fail without setting @err */
4260 error_setg(&err, QERR_JSON_PARSING);
4261 }
cf869d53 4262
0fa39d0b
MA
4263 qdict = qobject_to(QDict, req);
4264 if (qdict) {
4265 id = qobject_ref(qdict_get(qdict, "id"));
4266 qdict_del(qdict, "id");
4267 } /* else will fail qmp_dispatch() */
71da4667 4268
8720e63e 4269 if (req && trace_event_get_state_backends(TRACE_HANDLE_QMP_COMMAND)) {
45434ba4
MA
4270 QString *req_json = qobject_to_json(req);
4271 trace_handle_qmp_command(mon, qstring_get_str(req_json));
4272 qobject_unref(req_json);
cf869d53
PX
4273 }
4274
69240fe6 4275 if (qdict && qmp_is_oob(qdict)) {
774a6b67 4276 /* OOB commands are executed immediately */
b2731456 4277 trace_monitor_qmp_cmd_out_of_band(qobject_get_try_str(id)
cf869d53 4278 ?: "");
b2731456 4279 monitor_qmp_dispatch(mon, req, id);
d1c384fa
MAL
4280 qobject_unref(req);
4281 qobject_unref(id);
cf869d53 4282 return;
cf869d53
PX
4283 }
4284
71da4667
PX
4285 req_obj = g_new0(QMPRequest, 1);
4286 req_obj->mon = mon;
b2731456 4287 req_obj->id = id;
71da4667 4288 req_obj->req = req;
1cc37471 4289 req_obj->err = err;
71da4667
PX
4290 req_obj->need_resume = false;
4291
bf1e7301
PX
4292 /* Protect qmp_requests and fetching its length. */
4293 qemu_mutex_lock(&mon->qmp.qmp_queue_lock);
4294
71da4667
PX
4295 /*
4296 * If OOB is not enabled on the current monitor, we'll emulate the
4297 * old behavior that we won't process the current monitor any more
4298 * until it has responded. This helps make sure that as long as
4299 * OOB is not enabled, the server will never drop any command.
4300 */
4301 if (!qmp_oob_enabled(mon)) {
4302 monitor_suspend(mon);
4303 req_obj->need_resume = true;
bf1e7301
PX
4304 } else {
4305 /* Drop the request if queue is full. */
4306 if (mon->qmp.qmp_requests->length >= QMP_REQ_QUEUE_LEN_MAX) {
4307 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
d621cfe0
MA
4308 /*
4309 * FIXME @id's scope is just @mon, and broadcasting it is
4310 * wrong. If another monitor's client has a command with
4311 * the same ID in flight, the event will incorrectly claim
4312 * that command was dropped.
4313 */
bf1e7301
PX
4314 qapi_event_send_command_dropped(id,
4315 COMMAND_DROP_REASON_QUEUE_FULL,
4316 &error_abort);
6d2d563f 4317 qmp_request_free(req_obj);
bf1e7301
PX
4318 return;
4319 }
71da4667
PX
4320 }
4321
4322 /*
4323 * Put the request to the end of queue so that requests will be
4324 * handled in time order. Ownership for req_obj, req, id,
4325 * etc. will be delivered to the handler side.
4326 */
71da4667
PX
4327 g_queue_push_tail(mon->qmp.qmp_requests, req_obj);
4328 qemu_mutex_unlock(&mon->qmp.qmp_queue_lock);
4329
4330 /* Kick the dispatcher routine */
cab5ad86 4331 qemu_bh_schedule(qmp_dispatcher_bh);
71da4667
PX
4332}
4333
c83fe23b 4334static void monitor_qmp_read(void *opaque, const uint8_t *buf, int size)
9b57c02e 4335{
227a0755 4336 Monitor *mon = opaque;
9b57c02e 4337
227a0755 4338 json_message_parser_feed(&mon->qmp.parser, (const char *) buf, size);
9b57c02e
LC
4339}
4340
731b0364 4341static void monitor_read(void *opaque, const uint8_t *buf, int size)
9dc39cba 4342{
731b0364 4343 Monitor *old_mon = cur_mon;
7e2515e8 4344 int i;
376253ec 4345
731b0364
AL
4346 cur_mon = opaque;
4347
cde76ee1
AL
4348 if (cur_mon->rs) {
4349 for (i = 0; i < size; i++)
4350 readline_handle_byte(cur_mon->rs, buf[i]);
4351 } else {
4352 if (size == 0 || buf[size - 1] != 0)
4353 monitor_printf(cur_mon, "corrupted command\n");
4354 else
7ef6cf63 4355 handle_hmp_command(cur_mon, (char *)buf);
cde76ee1 4356 }
9dc39cba 4357
731b0364
AL
4358 cur_mon = old_mon;
4359}
d8f44609 4360
c60bf339
SH
4361static void monitor_command_cb(void *opaque, const char *cmdline,
4362 void *readline_opaque)
aa455485 4363{
c60bf339
SH
4364 Monitor *mon = opaque;
4365
731b0364 4366 monitor_suspend(mon);
7ef6cf63 4367 handle_hmp_command(mon, cmdline);
731b0364 4368 monitor_resume(mon);
d8f44609
AL
4369}
4370
cde76ee1 4371int monitor_suspend(Monitor *mon)
d8f44609 4372{
e3e977d4 4373 if (monitor_is_hmp_non_interactive(mon)) {
cde76ee1 4374 return -ENOTTY;
e3e977d4
PX
4375 }
4376
df152fb9 4377 atomic_inc(&mon->suspend_cnt);
e3e977d4
PX
4378
4379 if (monitor_is_qmp(mon)) {
4380 /*
c5f57ed0 4381 * Kick I/O thread to make sure this takes effect. It'll be
e3e977d4
PX
4382 * evaluated again in prepare() of the watch object.
4383 */
cab5ad86 4384 aio_notify(iothread_get_aio_context(mon_iothread));
e3e977d4
PX
4385 }
4386
4387 trace_monitor_suspend(mon, 1);
cde76ee1 4388 return 0;
d8f44609
AL
4389}
4390
376253ec 4391void monitor_resume(Monitor *mon)
d8f44609 4392{
e3e977d4 4393 if (monitor_is_hmp_non_interactive(mon)) {
cde76ee1 4394 return;
e3e977d4
PX
4395 }
4396
df152fb9 4397 if (atomic_dec_fetch(&mon->suspend_cnt) == 0) {
e3e977d4
PX
4398 if (monitor_is_qmp(mon)) {
4399 /*
774a6b67
MA
4400 * For QMP monitors that are running in the I/O thread,
4401 * let's kick the thread in case it's sleeping.
e3e977d4 4402 */
f91dc2a0 4403 if (mon->use_io_thread) {
cab5ad86 4404 aio_notify(iothread_get_aio_context(mon_iothread));
e3e977d4
PX
4405 }
4406 } else {
4407 assert(mon->rs);
4408 readline_show_prompt(mon->rs);
4409 }
df152fb9 4410 }
e3e977d4 4411 trace_monitor_suspend(mon, -1);
aa455485
FB
4412}
4413
1816604b 4414static QDict *qmp_greeting(Monitor *mon)
ca9567e2 4415{
02130314 4416 QList *cap_list = qlist_new();
b9c15f16 4417 QObject *ver = NULL;
02130314 4418 QMPCapability cap;
ca9567e2 4419
7fad30f0 4420 qmp_marshal_query_version(NULL, &ver, NULL);
c823501e 4421
02130314 4422 for (cap = 0; cap < QMP_CAPABILITY__MAX; cap++) {
279f9e08
MA
4423 if (mon->qmp.capab_offered[cap]) {
4424 qlist_append_str(cap_list, QMPCapability_str(cap));
02130314 4425 }
02130314
PX
4426 }
4427
1816604b
MA
4428 return qdict_from_jsonf_nofail(
4429 "{'QMP': {'version': %p, 'capabilities': %p}}",
4430 ver, cap_list);
ca9567e2
LC
4431}
4432
c83fe23b 4433static void monitor_qmp_event(void *opaque, int event)
9b57c02e 4434{
1816604b 4435 QDict *data;
47116d1c 4436 Monitor *mon = opaque;
9b57c02e 4437
47116d1c
LC
4438 switch (event) {
4439 case CHR_EVENT_OPENED:
635db18f 4440 mon->qmp.commands = &qmp_cap_negotiation_commands;
02130314 4441 monitor_qmp_caps_reset(mon);
1816604b
MA
4442 data = qmp_greeting(mon);
4443 qmp_queue_response(mon, data);
cb3e7f08 4444 qobject_unref(data);
efb87c16 4445 mon_refcount++;
47116d1c
LC
4446 break;
4447 case CHR_EVENT_CLOSED:
c73a843b
PX
4448 /*
4449 * Note: this is only useful when the output of the chardev
4450 * backend is still open. For example, when the backend is
4451 * stdio, it's possible that stdout is still open when stdin
4452 * is closed.
4453 */
4454 monitor_qmp_response_flush(mon);
6d2d563f 4455 monitor_qmp_cleanup_queues(mon);
74358f2a
MA
4456 json_message_parser_destroy(&mon->qmp.parser);
4457 json_message_parser_init(&mon->qmp.parser, handle_qmp_command);
efb87c16
CB
4458 mon_refcount--;
4459 monitor_fdsets_cleanup();
47116d1c 4460 break;
9b57c02e
LC
4461 }
4462}
4463
731b0364 4464static void monitor_event(void *opaque, int event)
86e94dea 4465{
376253ec
AL
4466 Monitor *mon = opaque;
4467
2724b180
AL
4468 switch (event) {
4469 case CHR_EVENT_MUX_IN:
dc7cbcd8 4470 qemu_mutex_lock(&mon->mon_lock);
a7aec5da 4471 mon->mux_out = 0;
dc7cbcd8 4472 qemu_mutex_unlock(&mon->mon_lock);
a7aec5da
GH
4473 if (mon->reset_seen) {
4474 readline_restart(mon->rs);
4475 monitor_resume(mon);
4476 monitor_flush(mon);
4477 } else {
df152fb9 4478 atomic_mb_set(&mon->suspend_cnt, 0);
a7aec5da 4479 }
2724b180
AL
4480 break;
4481
4482 case CHR_EVENT_MUX_OUT:
a7aec5da 4483 if (mon->reset_seen) {
df152fb9 4484 if (atomic_mb_read(&mon->suspend_cnt) == 0) {
a7aec5da
GH
4485 monitor_printf(mon, "\n");
4486 }
4487 monitor_flush(mon);
4488 monitor_suspend(mon);
4489 } else {
df152fb9 4490 atomic_inc(&mon->suspend_cnt);
a7aec5da 4491 }
dc7cbcd8 4492 qemu_mutex_lock(&mon->mon_lock);
a7aec5da 4493 mon->mux_out = 1;
dc7cbcd8 4494 qemu_mutex_unlock(&mon->mon_lock);
2724b180 4495 break;
86e94dea 4496
b6b8df56 4497 case CHR_EVENT_OPENED:
2724b180
AL
4498 monitor_printf(mon, "QEMU %s monitor - type 'help' for more "
4499 "information\n", QEMU_VERSION);
a7aec5da 4500 if (!mon->mux_out) {
e5554e20 4501 readline_restart(mon->rs);
2724b180 4502 readline_show_prompt(mon->rs);
a7aec5da
GH
4503 }
4504 mon->reset_seen = 1;
efb87c16
CB
4505 mon_refcount++;
4506 break;
4507
4508 case CHR_EVENT_CLOSED:
4509 mon_refcount--;
4510 monitor_fdsets_cleanup();
2724b180
AL
4511 break;
4512 }
86e94dea
TS
4513}
4514
816f8925
WX
4515static int
4516compare_mon_cmd(const void *a, const void *b)
4517{
4518 return strcmp(((const mon_cmd_t *)a)->name,
4519 ((const mon_cmd_t *)b)->name);
4520}
4521
4522static void sortcmdlist(void)
4523{
4524 int array_num;
4525 int elem_size = sizeof(mon_cmd_t);
4526
4527 array_num = sizeof(mon_cmds)/elem_size-1;
4528 qsort((void *)mon_cmds, array_num, elem_size, compare_mon_cmd);
4529
4530 array_num = sizeof(info_cmds)/elem_size-1;
4531 qsort((void *)info_cmds, array_num, elem_size, compare_mon_cmd);
4532}
4533
a5ed3525
PX
4534static GMainContext *monitor_get_io_context(void)
4535{
cab5ad86 4536 return iothread_get_g_main_context(mon_iothread);
a5ed3525
PX
4537}
4538
4539static AioContext *monitor_get_aio_context(void)
4540{
cab5ad86 4541 return iothread_get_aio_context(mon_iothread);
a5ed3525
PX
4542}
4543
4544static void monitor_iothread_init(void)
4545{
cab5ad86 4546 mon_iothread = iothread_create("mon_iothread", &error_abort);
71da4667
PX
4547
4548 /*
774a6b67
MA
4549 * The dispatcher BH must run in the main loop thread, since we
4550 * have commands assuming that context. It would be nice to get
4551 * rid of those assumptions.
71da4667 4552 */
cab5ad86
MA
4553 qmp_dispatcher_bh = aio_bh_new(iohandler_get_aio_context(),
4554 monitor_qmp_bh_dispatcher,
4555 NULL);
abe3cd0f
PX
4556
4557 /*
774a6b67
MA
4558 * The responder BH must be run in the monitor I/O thread, so that
4559 * monitors that are using the I/O thread have their output
4560 * written by the I/O thread.
abe3cd0f 4561 */
cab5ad86
MA
4562 qmp_respond_bh = aio_bh_new(monitor_get_aio_context(),
4563 monitor_qmp_bh_responder,
4564 NULL);
a5ed3525
PX
4565}
4566
6adf08dd
PX
4567void monitor_init_globals(void)
4568{
4569 monitor_init_qmp_commands();
4570 monitor_qapi_event_init();
4571 sortcmdlist();
4572 qemu_mutex_init(&monitor_lock);
47451466 4573 qemu_mutex_init(&mon_fdsets_lock);
a5ed3525 4574 monitor_iothread_init();
6adf08dd
PX
4575}
4576
c60bf339
SH
4577/* These functions just adapt the readline interface in a typesafe way. We
4578 * could cast function pointers but that discards compiler checks.
4579 */
d5d1507b
SW
4580static void GCC_FMT_ATTR(2, 3) monitor_readline_printf(void *opaque,
4581 const char *fmt, ...)
c60bf339
SH
4582{
4583 va_list ap;
4584 va_start(ap, fmt);
4585 monitor_vprintf(opaque, fmt, ap);
4586 va_end(ap);
4587}
4588
4589static void monitor_readline_flush(void *opaque)
4590{
4591 monitor_flush(opaque);
4592}
4593
397d30e9
PB
4594/*
4595 * Print to current monitor if we have one, else to stderr.
4596 * TODO should return int, so callers can calculate width, but that
4597 * requires surgery to monitor_vprintf(). Left for another day.
4598 */
4599void error_vprintf(const char *fmt, va_list ap)
4600{
4601 if (cur_mon && !monitor_cur_is_qmp()) {
4602 monitor_vprintf(cur_mon, fmt, ap);
4603 } else {
4604 vfprintf(stderr, fmt, ap);
4605 }
4606}
4607
4608void error_vprintf_unless_qmp(const char *fmt, va_list ap)
4609{
4610 if (cur_mon && !monitor_cur_is_qmp()) {
4611 monitor_vprintf(cur_mon, fmt, ap);
0d6b50d4
MAL
4612 } else if (!cur_mon) {
4613 vfprintf(stderr, fmt, ap);
397d30e9
PB
4614 }
4615}
4616
a5ed3525
PX
4617static void monitor_list_append(Monitor *mon)
4618{
4619 qemu_mutex_lock(&monitor_lock);
4620 QTAILQ_INSERT_HEAD(&mon_list, mon, entry);
4621 qemu_mutex_unlock(&monitor_lock);
4622}
4623
4624static void monitor_qmp_setup_handlers_bh(void *opaque)
4625{
4626 Monitor *mon = opaque;
4627 GMainContext *context;
4628
f91dc2a0 4629 if (mon->use_io_thread) {
774a6b67 4630 /* Use @mon_iothread context */
a5ed3525 4631 context = monitor_get_io_context();
a5ed3525
PX
4632 assert(context);
4633 } else {
774a6b67 4634 /* Use default main loop context */
a5ed3525
PX
4635 context = NULL;
4636 }
4637
4638 qemu_chr_fe_set_handlers(&mon->chr, monitor_can_read, monitor_qmp_read,
4639 monitor_qmp_event, NULL, mon, context, true);
4640 monitor_list_append(mon);
4641}
4642
0ec7b3e7 4643void monitor_init(Chardev *chr, int flags)
aa455485 4644{
6adf08dd 4645 Monitor *mon = g_malloc(sizeof(*mon));
be933ffc
PX
4646 bool use_readline = flags & MONITOR_USE_READLINE;
4647 bool use_oob = flags & MONITOR_USE_OOB;
4648
4649 if (use_oob) {
4650 if (CHARDEV_IS_MUX(chr)) {
c0698212 4651 error_report("Monitor out-of-band is not supported with "
be933ffc
PX
4652 "MUX typed chardev backend");
4653 exit(1);
4654 }
4655 if (use_readline) {
c0698212 4656 error_report("Monitor out-of-band is only supported by QMP");
be933ffc
PX
4657 exit(1);
4658 }
4659 }
87127161 4660
be933ffc 4661 monitor_data_init(mon, false, use_oob);
20d8a3ed 4662
32a6ebec 4663 qemu_chr_fe_init(&mon->chr, chr, &error_abort);
731b0364 4664 mon->flags = flags;
be933ffc 4665 if (use_readline) {
c60bf339
SH
4666 mon->rs = readline_init(monitor_readline_printf,
4667 monitor_readline_flush,
4668 mon,
4669 monitor_find_completion);
cde76ee1
AL
4670 monitor_read_command(mon, 0);
4671 }
87127161 4672
9f3982f2 4673 if (monitor_is_qmp(mon)) {
5345fdb4 4674 qemu_chr_fe_set_echo(&mon->chr, true);
74358f2a 4675 json_message_parser_init(&mon->qmp.parser, handle_qmp_command);
f91dc2a0 4676 if (mon->use_io_thread) {
a5ed3525
PX
4677 /*
4678 * Make sure the old iowatch is gone. It's possible when
4679 * e.g. the chardev is in client mode, with wait=on.
4680 */
4681 remove_fd_in_watch(chr);
4682 /*
4683 * We can't call qemu_chr_fe_set_handlers() directly here
774a6b67
MA
4684 * since chardev might be running in the monitor I/O
4685 * thread. Schedule a bottom half.
a5ed3525
PX
4686 */
4687 aio_bh_schedule_oneshot(monitor_get_aio_context(),
4688 monitor_qmp_setup_handlers_bh, mon);
774a6b67 4689 /* The bottom half will add @mon to @mon_list */
a5ed3525
PX
4690 return;
4691 } else {
4692 qemu_chr_fe_set_handlers(&mon->chr, monitor_can_read,
4693 monitor_qmp_read, monitor_qmp_event,
4694 NULL, mon, NULL, true);
4695 }
9b57c02e 4696 } else {
5345fdb4 4697 qemu_chr_fe_set_handlers(&mon->chr, monitor_can_read, monitor_read,
81517ba3 4698 monitor_event, NULL, mon, NULL, true);
9b57c02e 4699 }
87127161 4700
a5ed3525 4701 monitor_list_append(mon);
aa455485
FB
4702}
4703
2ef45716
MAL
4704void monitor_cleanup(void)
4705{
4706 Monitor *mon, *next;
4707
a5ed3525 4708 /*
c5f57ed0 4709 * We need to explicitly stop the I/O thread (but not destroy it),
774a6b67 4710 * clean up the monitor resources, then destroy the I/O thread since
a5ed3525
PX
4711 * we need to unregister from chardev below in
4712 * monitor_data_destroy(), and chardev is not thread-safe yet
4713 */
cab5ad86 4714 iothread_stop(mon_iothread);
a5ed3525 4715
abe3cd0f 4716 /*
774a6b67
MA
4717 * Flush all response queues. Note that even after this flush,
4718 * data may remain in output buffers.
abe3cd0f
PX
4719 */
4720 monitor_qmp_bh_responder(NULL);
4721
774a6b67 4722 /* Flush output buffers and destroy monitors */
2ef45716 4723 qemu_mutex_lock(&monitor_lock);
238d9f34
PX
4724 QTAILQ_FOREACH_SAFE(mon, &mon_list, entry, next) {
4725 QTAILQ_REMOVE(&mon_list, mon, entry);
abe3cd0f 4726 monitor_flush(mon);
2ef45716
MAL
4727 monitor_data_destroy(mon);
4728 g_free(mon);
4729 }
4730 qemu_mutex_unlock(&monitor_lock);
a5ed3525 4731
c5f57ed0 4732 /* QEMUBHs needs to be deleted before destroying the I/O thread */
cab5ad86
MA
4733 qemu_bh_delete(qmp_dispatcher_bh);
4734 qmp_dispatcher_bh = NULL;
4735 qemu_bh_delete(qmp_respond_bh);
4736 qmp_respond_bh = NULL;
71da4667 4737
cab5ad86
MA
4738 iothread_destroy(mon_iothread);
4739 mon_iothread = NULL;
2ef45716
MAL
4740}
4741
4d454574
PB
4742QemuOptsList qemu_mon_opts = {
4743 .name = "mon",
4744 .implied_opt_name = "chardev",
4745 .head = QTAILQ_HEAD_INITIALIZER(qemu_mon_opts.head),
4746 .desc = {
4747 {
4748 .name = "mode",
4749 .type = QEMU_OPT_STRING,
4750 },{
4751 .name = "chardev",
4752 .type = QEMU_OPT_STRING,
4d454574
PB
4753 },{
4754 .name = "pretty",
4755 .type = QEMU_OPT_BOOL,
be933ffc
PX
4756 },{
4757 .name = "x-oob",
4758 .type = QEMU_OPT_BOOL,
4d454574
PB
4759 },
4760 { /* end of list */ }
4761 },
4762};
f2ae8abf
MT
4763
4764#ifndef TARGET_I386
4765void qmp_rtc_reset_reinjection(Error **errp)
4766{
c6bd8c70 4767 error_setg(errp, QERR_FEATURE_DISABLED, "rtc-reset-reinjection");
f2ae8abf 4768}
08a161fd
BS
4769
4770SevInfo *qmp_query_sev(Error **errp)
4771{
4772 error_setg(errp, QERR_FEATURE_DISABLED, "query-sev");
4773 return NULL;
4774}
1b6a034f
BS
4775
4776SevLaunchMeasureInfo *qmp_query_sev_launch_measure(Error **errp)
4777{
4778 error_setg(errp, QERR_FEATURE_DISABLED, "query-sev-launch-measure");
4779 return NULL;
4780}
31dd67f6
BS
4781
4782SevCapability *qmp_query_sev_capabilities(Error **errp)
4783{
4784 error_setg(errp, QERR_FEATURE_DISABLED, "query-sev-capabilities");
4785 return NULL;
4786}
f2ae8abf 4787#endif
7ee0c3e3
JH
4788
4789#ifndef TARGET_S390X
4790void qmp_dump_skeys(const char *filename, Error **errp)
4791{
4792 error_setg(errp, QERR_FEATURE_DISABLED, "dump-skeys");
4793}
4794#endif
ae50a770
PX
4795
4796#ifndef TARGET_ARM
4797GICCapabilityList *qmp_query_gic_capabilities(Error **errp)
4798{
4799 error_setg(errp, QERR_FEATURE_DISABLED, "query-gic-capabilities");
4800 return NULL;
4801}
4802#endif
d4633541
IM
4803
4804HotpluggableCPUList *qmp_query_hotpluggable_cpus(Error **errp)
4805{
4806 MachineState *ms = MACHINE(qdev_get_machine());
4807 MachineClass *mc = MACHINE_GET_CLASS(ms);
4808
c5514d0e 4809 if (!mc->has_hotpluggable_cpus) {
d4633541
IM
4810 error_setg(errp, QERR_FEATURE_DISABLED, "query-hotpluggable-cpus");
4811 return NULL;
4812 }
4813
c5514d0e 4814 return machine_query_hotpluggable_cpus(ms);
d4633541 4815}