qemu_monitor.h 34.6 KB
Newer Older
1 2 3
/*
 * qemu_monitor.h: interaction with QEMU monitor console
 *
4
 * Copyright (C) 2006-2014 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 "virbitmap.h"
32
# include "virhash.h"
33
# include "virjson.h"
34
# include "device_conf.h"
35
# include "cpu/cpu.h"
36

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

40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
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;

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

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

    qemuMonitorPasswordHandler passwordHandler;
    void *passwordOpaque;
};

J
Jiri Denemark 已提交
71 72

typedef void (*qemuMonitorDestroyCallback)(qemuMonitorPtr mon,
73 74
                                           virDomainObjPtr vm,
                                           void *opaque);
J
Jiri Denemark 已提交
75
typedef void (*qemuMonitorEofNotifyCallback)(qemuMonitorPtr mon,
76 77
                                             virDomainObjPtr vm,
                                             void *opaque);
J
Jiri Denemark 已提交
78
typedef void (*qemuMonitorErrorNotifyCallback)(qemuMonitorPtr mon,
79 80
                                               virDomainObjPtr vm,
                                               void *opaque);
J
Jiri Denemark 已提交
81 82 83 84 85 86 87 88 89 90
/* XXX we'd really like to avoid virConnectPtr here
 * 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
 */
typedef int (*qemuMonitorDiskSecretLookupCallback)(qemuMonitorPtr mon,
                                                   virConnectPtr conn,
                                                   virDomainObjPtr vm,
                                                   const char *path,
                                                   char **secret,
91 92
                                                   size_t *secretLen,
                                                   void *opaque);
93 94 95 96 97 98 99
typedef int (*qemuMonitorDomainEventCallback)(qemuMonitorPtr mon,
                                              virDomainObjPtr vm,
                                              const char *event,
                                              long long seconds,
                                              unsigned int micros,
                                              const char *details,
                                              void *opaque);
J
Jiri Denemark 已提交
100
typedef int (*qemuMonitorDomainShutdownCallback)(qemuMonitorPtr mon,
101 102
                                                 virDomainObjPtr vm,
                                                 void *opaque);
J
Jiri Denemark 已提交
103
typedef int (*qemuMonitorDomainResetCallback)(qemuMonitorPtr mon,
104 105
                                              virDomainObjPtr vm,
                                              void *opaque);
J
Jiri Denemark 已提交
106
typedef int (*qemuMonitorDomainPowerdownCallback)(qemuMonitorPtr mon,
107 108
                                                  virDomainObjPtr vm,
                                                  void *opaque);
J
Jiri Denemark 已提交
109
typedef int (*qemuMonitorDomainStopCallback)(qemuMonitorPtr mon,
110 111
                                             virDomainObjPtr vm,
                                             void *opaque);
J
Jiri Denemark 已提交
112
typedef int (*qemuMonitorDomainResumeCallback)(qemuMonitorPtr mon,
113 114
                                               virDomainObjPtr vm,
                                               void *opaque);
J
Jiri Denemark 已提交
115 116
typedef int (*qemuMonitorDomainRTCChangeCallback)(qemuMonitorPtr mon,
                                                  virDomainObjPtr vm,
117 118
                                                  long long offset,
                                                  void *opaque);
J
Jiri Denemark 已提交
119 120
typedef int (*qemuMonitorDomainWatchdogCallback)(qemuMonitorPtr mon,
                                                 virDomainObjPtr vm,
121 122
                                                 int action,
                                                 void *opaque);
J
Jiri Denemark 已提交
123 124 125 126
typedef int (*qemuMonitorDomainIOErrorCallback)(qemuMonitorPtr mon,
                                                virDomainObjPtr vm,
                                                const char *diskAlias,
                                                int action,
127 128
                                                const char *reason,
                                                void *opaque);
J
Jiri Denemark 已提交
129 130 131 132 133 134 135 136 137 138 139
typedef int (*qemuMonitorDomainGraphicsCallback)(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,
140 141
                                                 const char *saslUsername,
                                                 void *opaque);
J
Jiri Denemark 已提交
142 143 144 145
typedef int (*qemuMonitorDomainBlockJobCallback)(qemuMonitorPtr mon,
                                                 virDomainObjPtr vm,
                                                 const char *diskAlias,
                                                 int type,
146 147
                                                 int status,
                                                 void *opaque);
J
Jiri Denemark 已提交
148 149 150
typedef int (*qemuMonitorDomainTrayChangeCallback)(qemuMonitorPtr mon,
                                                   virDomainObjPtr vm,
                                                   const char *devAlias,
151 152
                                                   int reason,
                                                   void *opaque);
J
Jiri Denemark 已提交
153
typedef int (*qemuMonitorDomainPMWakeupCallback)(qemuMonitorPtr mon,
154 155
                                                 virDomainObjPtr vm,
                                                 void *opaque);
J
Jiri Denemark 已提交
156
typedef int (*qemuMonitorDomainPMSuspendCallback)(qemuMonitorPtr mon,
157 158
                                                  virDomainObjPtr vm,
                                                  void *opaque);
J
Jiri Denemark 已提交
159 160
typedef int (*qemuMonitorDomainBalloonChangeCallback)(qemuMonitorPtr mon,
                                                      virDomainObjPtr vm,
161 162
                                                      unsigned long long actual,
                                                      void *opaque);
J
Jiri Denemark 已提交
163
typedef int (*qemuMonitorDomainPMSuspendDiskCallback)(qemuMonitorPtr mon,
164 165
                                                      virDomainObjPtr vm,
                                                      void *opaque);
J
Jiri Denemark 已提交
166
typedef int (*qemuMonitorDomainGuestPanicCallback)(qemuMonitorPtr mon,
167 168
                                                   virDomainObjPtr vm,
                                                   void *opaque);
J
Jiri Denemark 已提交
169 170
typedef int (*qemuMonitorDomainDeviceDeletedCallback)(qemuMonitorPtr mon,
                                                      virDomainObjPtr vm,
171 172
                                                      const char *devAlias,
                                                      void *opaque);
J
Jiri Denemark 已提交
173

174 175 176
typedef struct _qemuMonitorCallbacks qemuMonitorCallbacks;
typedef qemuMonitorCallbacks *qemuMonitorCallbacksPtr;
struct _qemuMonitorCallbacks {
J
Jiri Denemark 已提交
177 178 179 180
    qemuMonitorDestroyCallback destroy;
    qemuMonitorEofNotifyCallback eofNotify;
    qemuMonitorErrorNotifyCallback errorNotify;
    qemuMonitorDiskSecretLookupCallback diskSecretLookup;
181
    qemuMonitorDomainEventCallback domainEvent;
J
Jiri Denemark 已提交
182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198
    qemuMonitorDomainShutdownCallback domainShutdown;
    qemuMonitorDomainResetCallback domainReset;
    qemuMonitorDomainPowerdownCallback domainPowerdown;
    qemuMonitorDomainStopCallback domainStop;
    qemuMonitorDomainResumeCallback domainResume;
    qemuMonitorDomainRTCChangeCallback domainRTCChange;
    qemuMonitorDomainWatchdogCallback domainWatchdog;
    qemuMonitorDomainIOErrorCallback domainIOError;
    qemuMonitorDomainGraphicsCallback domainGraphics;
    qemuMonitorDomainBlockJobCallback domainBlockJob;
    qemuMonitorDomainTrayChangeCallback domainTrayChange;
    qemuMonitorDomainPMWakeupCallback domainPMWakeup;
    qemuMonitorDomainPMSuspendCallback domainPMSuspend;
    qemuMonitorDomainBalloonChangeCallback domainBalloonChange;
    qemuMonitorDomainPMSuspendDiskCallback domainPMSuspendDisk;
    qemuMonitorDomainGuestPanicCallback domainGuestPanic;
    qemuMonitorDomainDeviceDeletedCallback domainDeviceDeleted;
199 200
};

201
char *qemuMonitorEscapeArg(const char *in);
202
char *qemuMonitorUnescapeArg(const char *in);
203

204
qemuMonitorPtr qemuMonitorOpen(virDomainObjPtr vm,
205
                               virDomainChrSourceDefPtr config,
E
Eric Blake 已提交
206
                               bool json,
207 208
                               qemuMonitorCallbacksPtr cb,
                               void *opaque)
209
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(4);
210 211
qemuMonitorPtr qemuMonitorOpenFD(virDomainObjPtr vm,
                                 int sockfd,
E
Eric Blake 已提交
212
                                 bool json,
213 214
                                 qemuMonitorCallbacksPtr cb,
                                 void *opaque)
215
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4);
216

217
void qemuMonitorClose(qemuMonitorPtr mon);
218

219
int qemuMonitorSetCapabilities(qemuMonitorPtr mon);
220

221 222
int qemuMonitorSetLink(qemuMonitorPtr mon,
                       const char *name,
223
                       virDomainNetInterfaceLinkState state);
224

225
/* These APIs are for use by the internal Text/JSON monitor impl code only */
226
char *qemuMonitorNextCommandID(qemuMonitorPtr mon);
227 228
int qemuMonitorSend(qemuMonitorPtr mon,
                    qemuMonitorMessagePtr msg);
229 230 231 232
virJSONValuePtr qemuMonitorGetOptions(qemuMonitorPtr mon)
    ATTRIBUTE_NONNULL(1);
void qemuMonitorSetOptions(qemuMonitorPtr mon, virJSONValuePtr options)
    ATTRIBUTE_NONNULL(1);
233 234 235 236 237 238
int qemuMonitorHMPCommandWithFd(qemuMonitorPtr mon,
                                const char *cmd,
                                int scm_fd,
                                char **reply);
# define qemuMonitorHMPCommand(mon, cmd, reply) \
    qemuMonitorHMPCommandWithFd(mon, cmd, -1, reply)
239

240
/* XXX same comment about virConnectPtr as above */
241 242 243 244 245
int qemuMonitorGetDiskSecret(qemuMonitorPtr mon,
                             virConnectPtr conn,
                             const char *path,
                             char **secret,
                             size_t *secretLen);
246

247 248 249
int qemuMonitorEmitEvent(qemuMonitorPtr mon, const char *event,
                         long long seconds, unsigned int micros,
                         const char *details);
250 251 252 253
int qemuMonitorEmitShutdown(qemuMonitorPtr mon);
int qemuMonitorEmitReset(qemuMonitorPtr mon);
int qemuMonitorEmitPowerdown(qemuMonitorPtr mon);
int qemuMonitorEmitStop(qemuMonitorPtr mon);
254
int qemuMonitorEmitResume(qemuMonitorPtr mon);
255
int qemuMonitorEmitRTCChange(qemuMonitorPtr mon, long long offset);
256
int qemuMonitorEmitWatchdog(qemuMonitorPtr mon, int action);
257 258
int qemuMonitorEmitIOError(qemuMonitorPtr mon,
                           const char *diskAlias,
259 260
                           int action,
                           const char *reason);
261 262 263 264 265 266 267 268 269 270 271
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);
272 273 274
int qemuMonitorEmitTrayChange(qemuMonitorPtr mon,
                              const char *devAlias,
                              int reason);
O
Osier Yang 已提交
275
int qemuMonitorEmitPMWakeup(qemuMonitorPtr mon);
O
Osier Yang 已提交
276
int qemuMonitorEmitPMSuspend(qemuMonitorPtr mon);
277 278 279 280
int qemuMonitorEmitBlockJob(qemuMonitorPtr mon,
                            const char *diskAlias,
                            int type,
                            int status);
281 282
int qemuMonitorEmitBalloonChange(qemuMonitorPtr mon,
                                 unsigned long long actual);
283
int qemuMonitorEmitPMSuspendDisk(qemuMonitorPtr mon);
284
int qemuMonitorEmitGuestPanic(qemuMonitorPtr mon);
285 286
int qemuMonitorEmitDeviceDeleted(qemuMonitorPtr mon,
                                 const char *devAlias);
287

288 289 290
int qemuMonitorStartCPUs(qemuMonitorPtr mon,
                         virConnectPtr conn);
int qemuMonitorStopCPUs(qemuMonitorPtr mon);
291 292 293 294 295 296 297 298 299 300 301 302 303 304 305

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,
306
    QEMU_MONITOR_VM_STATUS_GUEST_PANICKED,
307 308 309 310 311 312 313 314 315

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

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

317
int qemuMonitorSystemReset(qemuMonitorPtr mon);
318 319 320 321
int qemuMonitorSystemPowerdown(qemuMonitorPtr mon);

int qemuMonitorGetCPUInfo(qemuMonitorPtr mon,
                          int **pids);
322 323
int qemuMonitorGetVirtType(qemuMonitorPtr mon,
                           int *virtType);
324
int qemuMonitorGetBalloonInfo(qemuMonitorPtr mon,
325
                              unsigned long long *currmem);
326 327 328
int qemuMonitorGetMemoryStats(qemuMonitorPtr mon,
                              virDomainMemoryStatPtr stats,
                              unsigned int nr_stats);
329 330
int qemuMonitorSetMemoryStatsPeriod(qemuMonitorPtr mon,
                                    int period);
331

332
int qemuMonitorBlockIOStatusToError(const char *status);
333 334 335 336 337
virHashTablePtr qemuMonitorGetBlockInfo(qemuMonitorPtr mon);
struct qemuDomainDiskInfo *
qemuMonitorBlockInfoLookup(virHashTablePtr blockInfo,
                           const char *devname);

338
int qemuMonitorGetBlockStatsInfo(qemuMonitorPtr mon,
339
                                 const char *dev_name,
340 341
                                 long long *rd_req,
                                 long long *rd_bytes,
342
                                 long long *rd_total_times,
343 344
                                 long long *wr_req,
                                 long long *wr_bytes,
345 346 347
                                 long long *wr_total_times,
                                 long long *flush_req,
                                 long long *flush_total_times,
348
                                 long long *errs);
349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368

typedef struct _qemuBlockStats qemuBlockStats;
typedef qemuBlockStats *qemuBlockStatsPtr;
struct _qemuBlockStats {
    long long rd_req;
    long long rd_bytes;
    long long wr_req;
    long long wr_bytes;
    long long rd_total_times;
    long long wr_total_times;
    long long flush_req;
    long long flush_total_times;
};

int qemuMonitorGetAllBlockStatsInfo(qemuMonitorPtr mon,
                                    const char *dev_name,
                                    qemuBlockStatsPtr stats,
                                    int nstats)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);

369 370
int qemuMonitorGetBlockStatsParamsNumber(qemuMonitorPtr mon,
                                         int *nparams);
371

372
int qemuMonitorGetBlockExtent(qemuMonitorPtr mon,
373
                              const char *dev_name,
374
                              unsigned long long *extent);
375 376 377
int qemuMonitorBlockResize(qemuMonitorPtr mon,
                           const char *devname,
                           unsigned long long size);
378 379
int qemuMonitorSetVNCPassword(qemuMonitorPtr mon,
                              const char *password);
380 381 382 383 384 385 386
int qemuMonitorSetPassword(qemuMonitorPtr mon,
                           int type,
                           const char *password,
                           const char *action_if_connected);
int qemuMonitorExpirePassword(qemuMonitorPtr mon,
                              int type,
                              const char *expire_time);
387 388
int qemuMonitorSetBalloon(qemuMonitorPtr mon,
                          unsigned long newmem);
389
int qemuMonitorSetCPU(qemuMonitorPtr mon, int cpu, bool online);
390

391 392 393 394 395 396

/* XXX should we pass the virDomainDiskDefPtr instead
 * and hide devname details inside monitor. Reconsider
 * this when doing the QMP implementation
 */
int qemuMonitorEjectMedia(qemuMonitorPtr mon,
397
                          const char *dev_name,
398
                          bool force);
399
int qemuMonitorChangeMedia(qemuMonitorPtr mon,
400
                           const char *dev_name,
401 402
                           const char *newmedia,
                           const char *format);
403 404 405 406 407 408 409 410 411 412 413 414 415 416


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);

417 418 419
int qemuMonitorSetMigrationDowntime(qemuMonitorPtr mon,
                                    unsigned long long downtime);

420 421 422 423 424
int qemuMonitorGetMigrationCacheSize(qemuMonitorPtr mon,
                                     unsigned long long *cacheSize);
int qemuMonitorSetMigrationCacheSize(qemuMonitorPtr mon,
                                     unsigned long long cacheSize);

425 426 427 428 429 430
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,
M
Michael Avdienko 已提交
431
    QEMU_MONITOR_MIGRATION_STATUS_SETUP,
432 433 434 435

    QEMU_MONITOR_MIGRATION_STATUS_LAST
};

436 437
VIR_ENUM_DECL(qemuMonitorMigrationStatus)

438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466
typedef struct _qemuMonitorMigrationStatus qemuMonitorMigrationStatus;
typedef qemuMonitorMigrationStatus *qemuMonitorMigrationStatusPtr;
struct _qemuMonitorMigrationStatus {
    int status;
    unsigned long long total_time;
    /* total or expected depending on status */
    bool downtime_set;
    unsigned long long downtime;

    unsigned long long ram_transferred;
    unsigned long long ram_remaining;
    unsigned long long ram_total;
    bool ram_duplicate_set;
    unsigned long long ram_duplicate;
    unsigned long long ram_normal;
    unsigned long long ram_normal_bytes;

    unsigned long long disk_transferred;
    unsigned long long disk_remaining;
    unsigned long long disk_total;

    bool xbzrle_set;
    unsigned long long xbzrle_cache_size;
    unsigned long long xbzrle_bytes;
    unsigned long long xbzrle_pages;
    unsigned long long xbzrle_cache_miss;
    unsigned long long xbzrle_overflow;
};

467
int qemuMonitorGetMigrationStatus(qemuMonitorPtr mon,
468
                                  qemuMonitorMigrationStatusPtr status);
469 470
int qemuMonitorGetSpiceMigrationStatus(qemuMonitorPtr mon,
                                       bool *spice_migrated);
471

472 473
typedef enum {
    QEMU_MONITOR_MIGRATION_CAPS_XBZRLE,
474
    QEMU_MONITOR_MIGRATION_CAPS_AUTO_CONVERGE,
475 476 477 478 479 480 481 482 483 484 485

    QEMU_MONITOR_MIGRATION_CAPS_LAST
} qemuMonitorMigrationCaps;

VIR_ENUM_DECL(qemuMonitorMigrationCaps);

int qemuMonitorGetMigrationCapability(qemuMonitorPtr mon,
                                      qemuMonitorMigrationCaps capability);
int qemuMonitorSetMigrationCapability(qemuMonitorPtr mon,
                                      qemuMonitorMigrationCaps capability);

486
typedef enum {
E
Eric Blake 已提交
487
  QEMU_MONITOR_MIGRATE_BACKGROUND	= 1 << 0,
488 489 490 491 492
  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 已提交
493 494 495 496
int qemuMonitorMigrateToFd(qemuMonitorPtr mon,
                           unsigned int flags,
                           int fd);

497
int qemuMonitorMigrateToHost(qemuMonitorPtr mon,
498
                             unsigned int flags,
499 500 501 502
                             const char *hostname,
                             int port);

int qemuMonitorMigrateToCommand(qemuMonitorPtr mon,
503
                                unsigned int flags,
504 505
                                const char * const *argv);

506 507 508 509 510 511 512
/* 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.
513
 */
514 515
# define QEMU_MONITOR_MIGRATE_TO_FILE_BS (1024llu * 4)
# define QEMU_MONITOR_MIGRATE_TO_FILE_TRANSFER_SIZE (1024llu * 1024)
516 517

int qemuMonitorMigrateToFile(qemuMonitorPtr mon,
518
                             unsigned int flags,
519 520 521
                             const char * const *argv,
                             const char *target,
                             unsigned long long offset);
522 523

int qemuMonitorMigrateToUnix(qemuMonitorPtr mon,
524
                             unsigned int flags,
525 526 527 528
                             const char *unixfile);

int qemuMonitorMigrateCancel(qemuMonitorPtr mon);

529 530 531
int qemuMonitorGetDumpGuestMemoryCapability(qemuMonitorPtr mon,
                                            const char *capability);

532
int qemuMonitorDumpToFd(qemuMonitorPtr mon,
533 534
                        int fd,
                        const char *dumpformat);
535

536 537 538 539 540 541
int qemuMonitorGraphicsRelocate(qemuMonitorPtr mon,
                                int type,
                                const char *hostname,
                                int port,
                                int tlsPort,
                                const char *tlsSubject);
542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557

/* 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,
558 559
                                virDevicePCIAddress *hostAddr,
                                virDevicePCIAddress *guestAddr);
560 561 562 563 564 565 566

/* XXX disk driver type eg,  qcow/etc.
 * XXX cache mode
 */
int qemuMonitorAddPCIDisk(qemuMonitorPtr mon,
                          const char *path,
                          const char *bus,
567
                          virDevicePCIAddress *guestAddr);
568 569 570 571 572 573

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

int qemuMonitorRemovePCIDevice(qemuMonitorPtr mon,
577
                               virDevicePCIAddress *guestAddr);
578 579 580 581 582


int qemuMonitorSendFileHandle(qemuMonitorPtr mon,
                              const char *fdname,
                              int fd);
583
int qemuMonitorAddFd(qemuMonitorPtr mon, int fdset, int fd, const char *name);
584

585 586
/* These two functions preserve previous error and only set their own
 * error if no error was set before.
587
 */
588 589
int qemuMonitorCloseFileHandle(qemuMonitorPtr mon,
                               const char *fdname);
590
int qemuMonitorRemoveFd(qemuMonitorPtr mon, int fdset, int fd);
591 592 593 594 595

/* XXX do we really want to hardcode 'netstr' as the
 * sendable item here
 */
int qemuMonitorAddHostNetwork(qemuMonitorPtr mon,
596
                              const char *netstr,
597 598
                              int *tapfd, char **tapfdName, int tapfdSize,
                              int *vhostfd, char **vhostfdName, int vhostfdSize);
599 600 601 602 603

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

604
int qemuMonitorAddNetdev(qemuMonitorPtr mon,
605
                         const char *netdevstr,
606 607
                         int *tapfd, char **tapfdName, int tapfdSize,
                         int *vhostfd, char **vhostfdName, int vhostfdSize);
608 609 610 611

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

612 613
int qemuMonitorGetPtyPaths(qemuMonitorPtr mon,
                           virHashTablePtr paths);
614

615 616
int qemuMonitorAttachPCIDiskController(qemuMonitorPtr mon,
                                       const char *bus,
617
                                       virDevicePCIAddress *guestAddr);
618

619 620
int qemuMonitorAttachDrive(qemuMonitorPtr mon,
                           const char *drivestr,
621
                           virDevicePCIAddress *controllerAddr,
622 623
                           virDomainDeviceDriveAddress *driveAddr);

624 625 626 627 628

typedef struct _qemuMonitorPCIAddress qemuMonitorPCIAddress;
struct _qemuMonitorPCIAddress {
    unsigned int vendor;
    unsigned int product;
629
    virDevicePCIAddress addr;
630 631 632 633 634
};

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

635 636 637
int qemuMonitorAddDevice(qemuMonitorPtr mon,
                         const char *devicestr);

638 639 640 641 642
int qemuMonitorAddDeviceWithFd(qemuMonitorPtr mon,
                               const char *devicestr,
                               int fd,
                               const char *fdname);

643
int qemuMonitorDelDevice(qemuMonitorPtr mon,
644
                         const char *devalias);
645

646 647 648
int qemuMonitorAddDrive(qemuMonitorPtr mon,
                        const char *drivestr);

649
int qemuMonitorDriveDel(qemuMonitorPtr mon,
650 651
                        const char *drivestr);

652 653 654 655
int qemuMonitorSetDrivePassphrase(qemuMonitorPtr mon,
                                  const char *alias,
                                  const char *passphrase);

C
Chris Lalancette 已提交
656 657 658 659
int qemuMonitorCreateSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorLoadSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorDeleteSnapshot(qemuMonitorPtr mon, const char *name);

660
int qemuMonitorDiskSnapshot(qemuMonitorPtr mon,
661
                            virJSONValuePtr actions,
662
                            const char *device,
663 664 665
                            const char *file,
                            const char *format,
                            bool reuse);
666 667
int qemuMonitorTransaction(qemuMonitorPtr mon, virJSONValuePtr actions)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
668 669 670 671
int qemuMonitorDriveMirror(qemuMonitorPtr mon,
                           const char *device,
                           const char *file,
                           const char *format,
672
                           unsigned long long bandwidth,
673 674
                           unsigned int granularity,
                           unsigned long long buf_size,
675 676 677 678 679 680 681
                           unsigned int flags)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);
int qemuMonitorDrivePivot(qemuMonitorPtr mon,
                          const char *device,
                          const char *file,
                          const char *format)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);
682

683 684 685 686
int qemuMonitorBlockCommit(qemuMonitorPtr mon,
                           const char *device,
                           const char *top,
                           const char *base,
687
                           const char *backingName,
688
                           unsigned long long bandwidth)
689 690
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
    ATTRIBUTE_NONNULL(4);
691
bool qemuMonitorSupportsActiveCommit(qemuMonitorPtr mon);
692

693 694 695 696
int qemuMonitorArbitraryCommand(qemuMonitorPtr mon,
                                const char *cmd,
                                char **reply,
                                bool hmp);
697

698 699
int qemuMonitorInjectNMI(qemuMonitorPtr mon);

700 701 702
int qemuMonitorScreendump(qemuMonitorPtr mon,
                          const char *file);

703 704 705 706 707
int qemuMonitorSendKey(qemuMonitorPtr mon,
                       unsigned int holdtime,
                       unsigned int *keycodes,
                       unsigned int nkeycodes);

708
typedef enum {
709 710 711 712
    BLOCK_JOB_ABORT,
    BLOCK_JOB_SPEED,
    BLOCK_JOB_PULL,
} qemuMonitorBlockJobCmd;
713 714 715

int qemuMonitorBlockJob(qemuMonitorPtr mon,
                        const char *device,
716 717
                        const char *base,
                        const char *backingName,
718
                        unsigned long long bandwidth,
719 720
                        qemuMonitorBlockJobCmd mode,
                        bool modern)
721
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
722

723 724
int qemuMonitorBlockJobInfo(qemuMonitorPtr mon,
                            const char *device,
725 726
                            virDomainBlockJobInfoPtr info,
                            unsigned long long *bandwidth)
727 728
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

729 730 731 732 733 734
int qemuMonitorOpenGraphics(qemuMonitorPtr mon,
                            const char *protocol,
                            int fd,
                            const char *fdname,
                            bool skipauth);

735 736 737 738 739 740 741 742
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
                                  const char *device,
                                  virDomainBlockIoTuneInfoPtr info);

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

743 744
int qemuMonitorSystemWakeup(qemuMonitorPtr mon);

745 746 747 748 749 750 751
int qemuMonitorGetVersion(qemuMonitorPtr mon,
                          int *major,
                          int *minor,
                          int *micro,
                          char **package)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(4);

752 753 754 755 756 757 758 759

typedef struct _qemuMonitorMachineInfo qemuMonitorMachineInfo;
typedef qemuMonitorMachineInfo *qemuMonitorMachineInfoPtr;

struct _qemuMonitorMachineInfo {
    char *name;
    bool isDefault;
    char *alias;
760
    unsigned int maxCpus;
761 762 763 764 765 766 767
};

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

void qemuMonitorMachineInfoFree(qemuMonitorMachineInfoPtr machine);

768 769 770
int qemuMonitorGetCPUDefinitions(qemuMonitorPtr mon,
                                 char ***cpus);

771 772
int qemuMonitorGetCommands(qemuMonitorPtr mon,
                           char ***commands);
773 774
int qemuMonitorGetEvents(qemuMonitorPtr mon,
                         char ***events);
775 776
int qemuMonitorGetCommandLineOptionParameters(qemuMonitorPtr mon,
                                              const char *option,
777 778
                                              char ***params,
                                              bool *found);
779

780 781 782 783
int qemuMonitorGetKVMState(qemuMonitorPtr mon,
                           bool *enabled,
                           bool *present);

784 785
int qemuMonitorGetObjectTypes(qemuMonitorPtr mon,
                              char ***types);
786 787 788
int qemuMonitorGetObjectProps(qemuMonitorPtr mon,
                              const char *type,
                              char ***props);
789
char *qemuMonitorGetTargetArch(qemuMonitorPtr mon);
790

791 792 793
int qemuMonitorNBDServerStart(qemuMonitorPtr mon,
                              const char *host,
                              unsigned int port);
794 795 796
int qemuMonitorNBDServerAdd(qemuMonitorPtr mon,
                            const char *deviceID,
                            bool writable);
797
int qemuMonitorNBDServerStop(qemuMonitorPtr);
S
Stefan Berger 已提交
798 799 800 801 802 803
int qemuMonitorGetTPMModels(qemuMonitorPtr mon,
                            char ***tpmmodels);

int qemuMonitorGetTPMTypes(qemuMonitorPtr mon,
                           char ***tpmtypes);

804 805 806
int qemuMonitorAttachCharDev(qemuMonitorPtr mon,
                             const char *chrID,
                             virDomainChrSourceDefPtr chr);
807 808
int qemuMonitorDetachCharDev(qemuMonitorPtr mon,
                             const char *chrID);
809 810 811 812

int qemuMonitorGetDeviceAliases(qemuMonitorPtr mon,
                                char ***aliases);

813 814
int qemuMonitorSetDomainLog(qemuMonitorPtr mon, int logfd);

815 816 817
int qemuMonitorGetGuestCPU(qemuMonitorPtr mon,
                           virArch arch,
                           virCPUDataPtr *data);
818

819 820
int qemuMonitorRTCResetReinjection(qemuMonitorPtr mon);

821 822 823 824 825 826 827 828 829 830 831 832
typedef struct _qemuMonitorIOThreadsInfo qemuMonitorIOThreadsInfo;
typedef qemuMonitorIOThreadsInfo *qemuMonitorIOThreadsInfoPtr;

struct _qemuMonitorIOThreadsInfo {
    char *name;
    int thread_id;
};
int qemuMonitorGetIOThreads(qemuMonitorPtr mon,
                            qemuMonitorIOThreadsInfoPtr **iothreads);

void qemuMonitorIOThreadsInfoFree(qemuMonitorIOThreadsInfoPtr iothread);

833 834 835 836 837 838 839 840 841 842 843 844 845
/**
 * 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

846
#endif /* QEMU_MONITOR_H */