qemu_monitor.h 23.3 KB
Newer Older
1 2 3
/*
 * qemu_monitor.h: interaction with QEMU monitor console
 *
4
 * Copyright (C) 2006-2012 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17
 * Copyright (C) 2006 Daniel P. Berrange
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
18
 * License along with this library.  If not, see
O
Osier Yang 已提交
19
 * <http://www.gnu.org/licenses/>.
20 21 22 23 24 25
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */


#ifndef QEMU_MONITOR_H
26
# define QEMU_MONITOR_H
27

28
# include "internal.h"
29

30
# include "domain_conf.h"
31
# include "bitmap.h"
32
# include "virhash.h"
33
# include "json.h"
34
# include "device_conf.h"
35

36 37
typedef struct _qemuMonitor qemuMonitor;
typedef qemuMonitor *qemuMonitorPtr;
38

39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
typedef struct _qemuMonitorMessage qemuMonitorMessage;
typedef qemuMonitorMessage *qemuMonitorMessagePtr;

typedef int (*qemuMonitorPasswordHandler)(qemuMonitorPtr mon,
                                          qemuMonitorMessagePtr msg,
                                          const char *data,
                                          size_t len,
                                          void *opaque);

struct _qemuMonitorMessage {
    int txFD;

    char *txBuffer;
    int txOffset;
    int txLength;

55
    /* Used by the text monitor reply / error */
56 57
    char *rxBuffer;
    int rxLength;
58 59
    /* Used by the JSON monitor to hold reply / error */
    void *rxObject;
60

61 62 63 64
    /* True if rxBuffer / rxObject are ready, or a
     * fatal error occurred on the monitor channel
     */
    bool finished;
65 66 67 68 69

    qemuMonitorPasswordHandler passwordHandler;
    void *passwordOpaque;
};

70 71 72
typedef struct _qemuMonitorCallbacks qemuMonitorCallbacks;
typedef qemuMonitorCallbacks *qemuMonitorCallbacksPtr;
struct _qemuMonitorCallbacks {
73 74 75
    void (*destroy)(qemuMonitorPtr mon,
                    virDomainObjPtr vm);

76
    void (*eofNotify)(qemuMonitorPtr mon,
77 78 79 80
                      virDomainObjPtr vm);
    void (*errorNotify)(qemuMonitorPtr mon,
                        virDomainObjPtr vm);
    /* XXX we'd really like to avoid virConnectPtr here
81 82 83 84 85 86 87 88 89 90
     * It is required so the callback can find the active
     * secret driver. Need to change this to work like the
     * security drivers do, to avoid this
     */
    int (*diskSecretLookup)(qemuMonitorPtr mon,
                            virConnectPtr conn,
                            virDomainObjPtr vm,
                            const char *path,
                            char **secret,
                            size_t *secretLen);
91 92 93 94 95 96 97 98 99

    int (*domainShutdown)(qemuMonitorPtr mon,
                          virDomainObjPtr vm);
    int (*domainReset)(qemuMonitorPtr mon,
                       virDomainObjPtr vm);
    int (*domainPowerdown)(qemuMonitorPtr mon,
                           virDomainObjPtr vm);
    int (*domainStop)(qemuMonitorPtr mon,
                      virDomainObjPtr vm);
100 101 102
    int (*domainRTCChange)(qemuMonitorPtr mon,
                           virDomainObjPtr vm,
                           long long offset);
103 104 105
    int (*domainWatchdog)(qemuMonitorPtr mon,
                          virDomainObjPtr vm,
                          int action);
106 107 108
    int (*domainIOError)(qemuMonitorPtr mon,
                         virDomainObjPtr vm,
                         const char *diskAlias,
109 110
                         int action,
                         const char *reason);
111 112 113 114 115 116 117 118 119 120 121 122
    int (*domainGraphics)(qemuMonitorPtr mon,
                          virDomainObjPtr vm,
                          int phase,
                          int localFamily,
                          const char *localNode,
                          const char *localService,
                          int remoteFamily,
                          const char *remoteNode,
                          const char *remoteService,
                          const char *authScheme,
                          const char *x509dname,
                          const char *saslUsername);
123 124 125 126 127
    int (*domainBlockJob)(qemuMonitorPtr mon,
                          virDomainObjPtr vm,
                          const char *diskAlias,
                          int type,
                          int status);
128 129 130 131
    int (*domainTrayChange)(qemuMonitorPtr mon,
                            virDomainObjPtr vm,
                            const char *devAlias,
                            int reason);
O
Osier Yang 已提交
132 133
    int (*domainPMWakeup)(qemuMonitorPtr mon,
                          virDomainObjPtr vm);
O
Osier Yang 已提交
134 135
    int (*domainPMSuspend)(qemuMonitorPtr mon,
                           virDomainObjPtr vm);
136 137 138
    int (*domainBalloonChange)(qemuMonitorPtr mon,
                               virDomainObjPtr vm,
                               unsigned long long actual);
139 140
};

141
char *qemuMonitorEscapeArg(const char *in);
142
char *qemuMonitorUnescapeArg(const char *in);
143

144
qemuMonitorPtr qemuMonitorOpen(virDomainObjPtr vm,
145
                               virDomainChrSourceDefPtr config,
D
Daniel P. Berrange 已提交
146
                               int json,
147 148
                               qemuMonitorCallbacksPtr cb)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(4);
149 150 151 152 153
qemuMonitorPtr qemuMonitorOpenFD(virDomainObjPtr vm,
                                 int sockfd,
                                 int json,
                                 qemuMonitorCallbacksPtr cb)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4);
154

155
void qemuMonitorClose(qemuMonitorPtr mon);
156

157
int qemuMonitorSetCapabilities(qemuMonitorPtr mon);
158

159 160 161
void qemuMonitorLock(qemuMonitorPtr mon);
void qemuMonitorUnlock(qemuMonitorPtr mon);

162 163 164 165
int qemuMonitorSetLink(qemuMonitorPtr mon,
                       const char *name,
                       enum virDomainNetInterfaceLinkState state) ;

166
/* These APIs are for use by the internal Text/JSON monitor impl code only */
167
char *qemuMonitorNextCommandID(qemuMonitorPtr mon);
168 169
int qemuMonitorSend(qemuMonitorPtr mon,
                    qemuMonitorMessagePtr msg);
170 171 172 173 174 175
int qemuMonitorHMPCommandWithFd(qemuMonitorPtr mon,
                                const char *cmd,
                                int scm_fd,
                                char **reply);
# define qemuMonitorHMPCommand(mon, cmd, reply) \
    qemuMonitorHMPCommandWithFd(mon, cmd, -1, reply)
176

177
/* XXX same comment about virConnectPtr as above */
178 179 180 181 182
int qemuMonitorGetDiskSecret(qemuMonitorPtr mon,
                             virConnectPtr conn,
                             const char *path,
                             char **secret,
                             size_t *secretLen);
183

184 185 186 187
int qemuMonitorEmitShutdown(qemuMonitorPtr mon);
int qemuMonitorEmitReset(qemuMonitorPtr mon);
int qemuMonitorEmitPowerdown(qemuMonitorPtr mon);
int qemuMonitorEmitStop(qemuMonitorPtr mon);
188
int qemuMonitorEmitRTCChange(qemuMonitorPtr mon, long long offset);
189
int qemuMonitorEmitWatchdog(qemuMonitorPtr mon, int action);
190 191
int qemuMonitorEmitIOError(qemuMonitorPtr mon,
                           const char *diskAlias,
192 193
                           int action,
                           const char *reason);
194 195 196 197 198 199 200 201 202 203 204
int qemuMonitorEmitGraphics(qemuMonitorPtr mon,
                            int phase,
                            int localFamily,
                            const char *localNode,
                            const char *localService,
                            int remoteFamily,
                            const char *remoteNode,
                            const char *remoteService,
                            const char *authScheme,
                            const char *x509dname,
                            const char *saslUsername);
205 206 207
int qemuMonitorEmitTrayChange(qemuMonitorPtr mon,
                              const char *devAlias,
                              int reason);
O
Osier Yang 已提交
208
int qemuMonitorEmitPMWakeup(qemuMonitorPtr mon);
O
Osier Yang 已提交
209
int qemuMonitorEmitPMSuspend(qemuMonitorPtr mon);
210 211 212 213
int qemuMonitorEmitBlockJob(qemuMonitorPtr mon,
                            const char *diskAlias,
                            int type,
                            int status);
214 215
int qemuMonitorEmitBalloonChange(qemuMonitorPtr mon,
                                 unsigned long long actual);
216

217 218 219
int qemuMonitorStartCPUs(qemuMonitorPtr mon,
                         virConnectPtr conn);
int qemuMonitorStopCPUs(qemuMonitorPtr mon);
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243

typedef enum {
    QEMU_MONITOR_VM_STATUS_DEBUG,
    QEMU_MONITOR_VM_STATUS_INMIGRATE,
    QEMU_MONITOR_VM_STATUS_INTERNAL_ERROR,
    QEMU_MONITOR_VM_STATUS_IO_ERROR,
    QEMU_MONITOR_VM_STATUS_PAUSED,
    QEMU_MONITOR_VM_STATUS_POSTMIGRATE,
    QEMU_MONITOR_VM_STATUS_PRELAUNCH,
    QEMU_MONITOR_VM_STATUS_FINISH_MIGRATE,
    QEMU_MONITOR_VM_STATUS_RESTORE_VM,
    QEMU_MONITOR_VM_STATUS_RUNNING,
    QEMU_MONITOR_VM_STATUS_SAVE_VM,
    QEMU_MONITOR_VM_STATUS_SHUTDOWN,
    QEMU_MONITOR_VM_STATUS_WATCHDOG,

    QEMU_MONITOR_VM_STATUS_LAST
} qemuMonitorVMStatus;
VIR_ENUM_DECL(qemuMonitorVMStatus)
int qemuMonitorVMStatusToPausedReason(const char *status);

int qemuMonitorGetStatus(qemuMonitorPtr mon,
                         bool *running,
                         virDomainPausedReason *reason);
244

245
int qemuMonitorSystemReset(qemuMonitorPtr mon);
246 247 248 249
int qemuMonitorSystemPowerdown(qemuMonitorPtr mon);

int qemuMonitorGetCPUInfo(qemuMonitorPtr mon,
                          int **pids);
250 251
int qemuMonitorGetVirtType(qemuMonitorPtr mon,
                           int *virtType);
252
int qemuMonitorGetBalloonInfo(qemuMonitorPtr mon,
253
                              unsigned long long *currmem);
254 255 256
int qemuMonitorGetMemoryStats(qemuMonitorPtr mon,
                              virDomainMemoryStatPtr stats,
                              unsigned int nr_stats);
257

258
int qemuMonitorBlockIOStatusToError(const char *status);
259 260 261 262 263
virHashTablePtr qemuMonitorGetBlockInfo(qemuMonitorPtr mon);
struct qemuDomainDiskInfo *
qemuMonitorBlockInfoLookup(virHashTablePtr blockInfo,
                           const char *devname);

264
int qemuMonitorGetBlockStatsInfo(qemuMonitorPtr mon,
265
                                 const char *dev_name,
266 267
                                 long long *rd_req,
                                 long long *rd_bytes,
268
                                 long long *rd_total_times,
269 270
                                 long long *wr_req,
                                 long long *wr_bytes,
271 272 273
                                 long long *wr_total_times,
                                 long long *flush_req,
                                 long long *flush_total_times,
274
                                 long long *errs);
275 276
int qemuMonitorGetBlockStatsParamsNumber(qemuMonitorPtr mon,
                                         int *nparams);
277

278
int qemuMonitorGetBlockExtent(qemuMonitorPtr mon,
279
                              const char *dev_name,
280
                              unsigned long long *extent);
281 282 283
int qemuMonitorBlockResize(qemuMonitorPtr mon,
                           const char *devname,
                           unsigned long long size);
284 285
int qemuMonitorSetVNCPassword(qemuMonitorPtr mon,
                              const char *password);
286 287 288 289 290 291 292
int qemuMonitorSetPassword(qemuMonitorPtr mon,
                           int type,
                           const char *password,
                           const char *action_if_connected);
int qemuMonitorExpirePassword(qemuMonitorPtr mon,
                              int type,
                              const char *expire_time);
293 294
int qemuMonitorSetBalloon(qemuMonitorPtr mon,
                          unsigned long newmem);
295 296
int qemuMonitorSetCPU(qemuMonitorPtr mon, int cpu, int online);

297 298 299 300 301 302

/* XXX should we pass the virDomainDiskDefPtr instead
 * and hide devname details inside monitor. Reconsider
 * this when doing the QMP implementation
 */
int qemuMonitorEjectMedia(qemuMonitorPtr mon,
303
                          const char *dev_name,
304
                          bool force);
305
int qemuMonitorChangeMedia(qemuMonitorPtr mon,
306
                           const char *dev_name,
307 308
                           const char *newmedia,
                           const char *format);
309 310 311 312 313 314 315 316 317 318 319 320 321 322


int qemuMonitorSaveVirtualMemory(qemuMonitorPtr mon,
                                 unsigned long long offset,
                                 size_t length,
                                 const char *path);
int qemuMonitorSavePhysicalMemory(qemuMonitorPtr mon,
                                  unsigned long long offset,
                                  size_t length,
                                  const char *path);

int qemuMonitorSetMigrationSpeed(qemuMonitorPtr mon,
                                 unsigned long bandwidth);

323 324 325
int qemuMonitorSetMigrationDowntime(qemuMonitorPtr mon,
                                    unsigned long long downtime);

326 327 328 329 330 331 332 333 334 335
enum {
    QEMU_MONITOR_MIGRATION_STATUS_INACTIVE,
    QEMU_MONITOR_MIGRATION_STATUS_ACTIVE,
    QEMU_MONITOR_MIGRATION_STATUS_COMPLETED,
    QEMU_MONITOR_MIGRATION_STATUS_ERROR,
    QEMU_MONITOR_MIGRATION_STATUS_CANCELLED,

    QEMU_MONITOR_MIGRATION_STATUS_LAST
};

336 337
VIR_ENUM_DECL(qemuMonitorMigrationStatus)

338 339 340 341 342
int qemuMonitorGetMigrationStatus(qemuMonitorPtr mon,
                                  int *status,
                                  unsigned long long *transferred,
                                  unsigned long long *remaining,
                                  unsigned long long *total);
343 344
int qemuMonitorGetSpiceMigrationStatus(qemuMonitorPtr mon,
                                       bool *spice_migrated);
345

346
typedef enum {
E
Eric Blake 已提交
347
  QEMU_MONITOR_MIGRATE_BACKGROUND	= 1 << 0,
348 349 350 351 352
  QEMU_MONITOR_MIGRATE_NON_SHARED_DISK  = 1 << 1, /* migration with non-shared storage with full disk copy */
  QEMU_MONITOR_MIGRATE_NON_SHARED_INC   = 1 << 2, /* migration with non-shared storage with incremental copy */
  QEMU_MONITOR_MIGRATION_FLAGS_LAST
} QEMU_MONITOR_MIGRATE;

E
Eric Blake 已提交
353 354 355 356
int qemuMonitorMigrateToFd(qemuMonitorPtr mon,
                           unsigned int flags,
                           int fd);

357
int qemuMonitorMigrateToHost(qemuMonitorPtr mon,
358
                             unsigned int flags,
359 360 361 362
                             const char *hostname,
                             int port);

int qemuMonitorMigrateToCommand(qemuMonitorPtr mon,
363
                                unsigned int flags,
364 365
                                const char * const *argv);

366 367 368 369 370 371 372
/* In general, BS is the smallest fundamental block size we can use to
 * access a block device; everything must be aligned to a multiple of
 * this.  Linux generally supports a BS as small as 512, but with
 * newer disks with 4k sectors, performance is better if we guarantee
 * alignment to the sector size.  However, operating on BS-sized
 * blocks is painfully slow, so we also have a transfer size that is
 * larger but only aligned to the smaller block size.
373
 */
374 375
# define QEMU_MONITOR_MIGRATE_TO_FILE_BS (1024llu * 4)
# define QEMU_MONITOR_MIGRATE_TO_FILE_TRANSFER_SIZE (1024llu * 1024)
376 377

int qemuMonitorMigrateToFile(qemuMonitorPtr mon,
378
                             unsigned int flags,
379 380 381
                             const char * const *argv,
                             const char *target,
                             unsigned long long offset);
382 383

int qemuMonitorMigrateToUnix(qemuMonitorPtr mon,
384
                             unsigned int flags,
385 386 387 388
                             const char *unixfile);

int qemuMonitorMigrateCancel(qemuMonitorPtr mon);

389
int qemuMonitorDumpToFd(qemuMonitorPtr mon,
390
                        int fd);
391

392 393 394 395 396 397
int qemuMonitorGraphicsRelocate(qemuMonitorPtr mon,
                                int type,
                                const char *hostname,
                                int port,
                                int tlsPort,
                                const char *tlsSubject);
398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413

/* XXX disk driver type eg,  qcow/etc.
 * XXX cache mode
 */
int qemuMonitorAddUSBDisk(qemuMonitorPtr mon,
                          const char *path);

int qemuMonitorAddUSBDeviceExact(qemuMonitorPtr mon,
                                 int bus,
                                 int dev);
int qemuMonitorAddUSBDeviceMatch(qemuMonitorPtr mon,
                                 int vendor,
                                 int product);


int qemuMonitorAddPCIHostDevice(qemuMonitorPtr mon,
414 415
                                virDevicePCIAddress *hostAddr,
                                virDevicePCIAddress *guestAddr);
416 417 418 419 420 421 422

/* XXX disk driver type eg,  qcow/etc.
 * XXX cache mode
 */
int qemuMonitorAddPCIDisk(qemuMonitorPtr mon,
                          const char *path,
                          const char *bus,
423
                          virDevicePCIAddress *guestAddr);
424 425 426 427 428 429

/* XXX do we really want to hardcode 'nicstr' as the
 * sendable item here
 */
int qemuMonitorAddPCINetwork(qemuMonitorPtr mon,
                             const char *nicstr,
430
                             virDevicePCIAddress *guestAddr);
431 432

int qemuMonitorRemovePCIDevice(qemuMonitorPtr mon,
433
                               virDevicePCIAddress *guestAddr);
434 435 436 437 438 439


int qemuMonitorSendFileHandle(qemuMonitorPtr mon,
                              const char *fdname,
                              int fd);

440 441 442
/* The function preserves previous error and only sets it's own error if no
 * error was set before.
 */
443 444 445 446 447 448 449 450
int qemuMonitorCloseFileHandle(qemuMonitorPtr mon,
                               const char *fdname);


/* XXX do we really want to hardcode 'netstr' as the
 * sendable item here
 */
int qemuMonitorAddHostNetwork(qemuMonitorPtr mon,
451 452 453
                              const char *netstr,
                              int tapfd, const char *tapfd_name,
                              int vhostfd, const char *vhostfd_name);
454 455 456 457 458

int qemuMonitorRemoveHostNetwork(qemuMonitorPtr mon,
                                 int vlan,
                                 const char *netname);

459
int qemuMonitorAddNetdev(qemuMonitorPtr mon,
460 461 462
                         const char *netdevstr,
                         int tapfd, const char *tapfd_name,
                         int vhostfd, const char *vhostfd_name);
463 464 465 466

int qemuMonitorRemoveNetdev(qemuMonitorPtr mon,
                            const char *alias);

467 468
int qemuMonitorGetPtyPaths(qemuMonitorPtr mon,
                           virHashTablePtr paths);
469

470 471
int qemuMonitorAttachPCIDiskController(qemuMonitorPtr mon,
                                       const char *bus,
472
                                       virDevicePCIAddress *guestAddr);
473

474 475
int qemuMonitorAttachDrive(qemuMonitorPtr mon,
                           const char *drivestr,
476
                           virDevicePCIAddress *controllerAddr,
477 478
                           virDomainDeviceDriveAddress *driveAddr);

479 480 481 482 483

typedef struct _qemuMonitorPCIAddress qemuMonitorPCIAddress;
struct _qemuMonitorPCIAddress {
    unsigned int vendor;
    unsigned int product;
484
    virDevicePCIAddress addr;
485 486 487 488 489
};

int qemuMonitorGetAllPCIAddresses(qemuMonitorPtr mon,
                                  qemuMonitorPCIAddress **addrs);

490 491 492
int qemuMonitorAddDevice(qemuMonitorPtr mon,
                         const char *devicestr);

493 494 495 496 497
int qemuMonitorAddDeviceWithFd(qemuMonitorPtr mon,
                               const char *devicestr,
                               int fd,
                               const char *fdname);

498
int qemuMonitorDelDevice(qemuMonitorPtr mon,
499
                         const char *devalias);
500

501 502 503
int qemuMonitorAddDrive(qemuMonitorPtr mon,
                        const char *drivestr);

504
int qemuMonitorDriveDel(qemuMonitorPtr mon,
505 506
                        const char *drivestr);

507 508 509 510
int qemuMonitorSetDrivePassphrase(qemuMonitorPtr mon,
                                  const char *alias,
                                  const char *passphrase);

C
Chris Lalancette 已提交
511 512 513 514
int qemuMonitorCreateSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorLoadSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorDeleteSnapshot(qemuMonitorPtr mon, const char *name);

515
int qemuMonitorDiskSnapshot(qemuMonitorPtr mon,
516
                            virJSONValuePtr actions,
517
                            const char *device,
518 519 520
                            const char *file,
                            const char *format,
                            bool reuse);
521 522
int qemuMonitorTransaction(qemuMonitorPtr mon, virJSONValuePtr actions)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
523

524 525 526 527
int qemuMonitorArbitraryCommand(qemuMonitorPtr mon,
                                const char *cmd,
                                char **reply,
                                bool hmp);
528

529 530
int qemuMonitorInjectNMI(qemuMonitorPtr mon);

531 532 533
int qemuMonitorScreendump(qemuMonitorPtr mon,
                          const char *file);

534 535 536 537 538
int qemuMonitorSendKey(qemuMonitorPtr mon,
                       unsigned int holdtime,
                       unsigned int *keycodes,
                       unsigned int nkeycodes);

539
typedef enum {
540 541 542 543 544
    BLOCK_JOB_ABORT,
    BLOCK_JOB_INFO,
    BLOCK_JOB_SPEED,
    BLOCK_JOB_PULL,
} qemuMonitorBlockJobCmd;
545 546 547

int qemuMonitorBlockJob(qemuMonitorPtr mon,
                        const char *device,
548
                        const char *back,
549 550
                        unsigned long bandwidth,
                        virDomainBlockJobInfoPtr info,
551 552
                        qemuMonitorBlockJobCmd mode,
                        bool modern)
553
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
554

555 556 557 558 559 560
int qemuMonitorOpenGraphics(qemuMonitorPtr mon,
                            const char *protocol,
                            int fd,
                            const char *fdname,
                            bool skipauth);

561 562 563 564 565 566 567 568
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
                                  const char *device,
                                  virDomainBlockIoTuneInfoPtr info);

int qemuMonitorGetBlockIoThrottle(qemuMonitorPtr mon,
                                  const char *device,
                                  virDomainBlockIoTuneInfoPtr reply);

569 570
int qemuMonitorSystemWakeup(qemuMonitorPtr mon);

571 572 573 574 575 576 577
int qemuMonitorGetVersion(qemuMonitorPtr mon,
                          int *major,
                          int *minor,
                          int *micro,
                          char **package)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(4);

578 579 580 581 582 583 584 585 586 587 588 589 590 591 592

typedef struct _qemuMonitorMachineInfo qemuMonitorMachineInfo;
typedef qemuMonitorMachineInfo *qemuMonitorMachineInfoPtr;

struct _qemuMonitorMachineInfo {
    char *name;
    bool isDefault;
    char *alias;
};

int qemuMonitorGetMachines(qemuMonitorPtr mon,
                           qemuMonitorMachineInfoPtr **machines);

void qemuMonitorMachineInfoFree(qemuMonitorMachineInfoPtr machine);

593 594 595
int qemuMonitorGetCPUDefinitions(qemuMonitorPtr mon,
                                 char ***cpus);

596 597
int qemuMonitorGetCommands(qemuMonitorPtr mon,
                           char ***commands);
598 599
int qemuMonitorGetEvents(qemuMonitorPtr mon,
                         char ***events);
600

601 602
int qemuMonitorGetObjectTypes(qemuMonitorPtr mon,
                              char ***types);
603 604 605
int qemuMonitorGetObjectProps(qemuMonitorPtr mon,
                              const char *type,
                              char ***props);
606
char *qemuMonitorGetTargetArch(qemuMonitorPtr mon);
607

608 609 610 611 612 613 614 615 616 617 618 619 620
/**
 * When running two dd process and using <> redirection, we need a
 * shell that will not truncate files.  These two strings serve that
 * purpose.
 */
# ifdef VIR_WRAPPER_SHELL
#  define VIR_WRAPPER_SHELL_PREFIX VIR_WRAPPER_SHELL " -c '"
#  define VIR_WRAPPER_SHELL_SUFFIX "'"
# else
#  define VIR_WRAPPER_SHELL_PREFIX /* nothing */
#  define VIR_WRAPPER_SHELL_SUFFIX /* nothing */
# endif

621
#endif /* QEMU_MONITOR_H */