qemu_monitor.h 34.9 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
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;
446 447 448 449 450 451 452
    /*
     * Duration of the QEMU 'setup' state.
     * for RDMA, this may be on the order of several seconds
     * if pinning support is requested before the migration begins.
     */
    bool setup_time_set;
    unsigned long long setup_time;
453 454 455 456

    unsigned long long ram_transferred;
    unsigned long long ram_remaining;
    unsigned long long ram_total;
457
    unsigned long long ram_bps;
458 459 460 461 462 463 464 465
    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;
466
    unsigned long long disk_bps;
467 468 469 470 471 472 473 474 475

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

476
int qemuMonitorGetMigrationStatus(qemuMonitorPtr mon,
477
                                  qemuMonitorMigrationStatusPtr status);
478 479
int qemuMonitorGetSpiceMigrationStatus(qemuMonitorPtr mon,
                                       bool *spice_migrated);
480

481 482
typedef enum {
    QEMU_MONITOR_MIGRATION_CAPS_XBZRLE,
483
    QEMU_MONITOR_MIGRATION_CAPS_AUTO_CONVERGE,
484 485 486 487 488 489 490 491 492 493 494

    QEMU_MONITOR_MIGRATION_CAPS_LAST
} qemuMonitorMigrationCaps;

VIR_ENUM_DECL(qemuMonitorMigrationCaps);

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

495
typedef enum {
E
Eric Blake 已提交
496
  QEMU_MONITOR_MIGRATE_BACKGROUND	= 1 << 0,
497 498 499 500 501
  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 已提交
502 503 504 505
int qemuMonitorMigrateToFd(qemuMonitorPtr mon,
                           unsigned int flags,
                           int fd);

506
int qemuMonitorMigrateToHost(qemuMonitorPtr mon,
507
                             unsigned int flags,
508 509 510 511
                             const char *hostname,
                             int port);

int qemuMonitorMigrateToCommand(qemuMonitorPtr mon,
512
                                unsigned int flags,
513 514
                                const char * const *argv);

515 516 517 518 519 520 521
/* 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.
522
 */
523 524
# define QEMU_MONITOR_MIGRATE_TO_FILE_BS (1024llu * 4)
# define QEMU_MONITOR_MIGRATE_TO_FILE_TRANSFER_SIZE (1024llu * 1024)
525 526

int qemuMonitorMigrateToFile(qemuMonitorPtr mon,
527
                             unsigned int flags,
528 529 530
                             const char * const *argv,
                             const char *target,
                             unsigned long long offset);
531 532

int qemuMonitorMigrateToUnix(qemuMonitorPtr mon,
533
                             unsigned int flags,
534 535 536 537
                             const char *unixfile);

int qemuMonitorMigrateCancel(qemuMonitorPtr mon);

538 539 540
int qemuMonitorGetDumpGuestMemoryCapability(qemuMonitorPtr mon,
                                            const char *capability);

541
int qemuMonitorDumpToFd(qemuMonitorPtr mon,
542 543
                        int fd,
                        const char *dumpformat);
544

545 546 547 548 549 550
int qemuMonitorGraphicsRelocate(qemuMonitorPtr mon,
                                int type,
                                const char *hostname,
                                int port,
                                int tlsPort,
                                const char *tlsSubject);
551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566

/* 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,
567 568
                                virDevicePCIAddress *hostAddr,
                                virDevicePCIAddress *guestAddr);
569 570 571 572 573 574 575

/* XXX disk driver type eg,  qcow/etc.
 * XXX cache mode
 */
int qemuMonitorAddPCIDisk(qemuMonitorPtr mon,
                          const char *path,
                          const char *bus,
576
                          virDevicePCIAddress *guestAddr);
577 578 579 580 581 582

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

int qemuMonitorRemovePCIDevice(qemuMonitorPtr mon,
586
                               virDevicePCIAddress *guestAddr);
587 588 589 590 591


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

594 595
/* These two functions preserve previous error and only set their own
 * error if no error was set before.
596
 */
597 598
int qemuMonitorCloseFileHandle(qemuMonitorPtr mon,
                               const char *fdname);
599
int qemuMonitorRemoveFd(qemuMonitorPtr mon, int fdset, int fd);
600 601 602 603 604

/* XXX do we really want to hardcode 'netstr' as the
 * sendable item here
 */
int qemuMonitorAddHostNetwork(qemuMonitorPtr mon,
605
                              const char *netstr,
606 607
                              int *tapfd, char **tapfdName, int tapfdSize,
                              int *vhostfd, char **vhostfdName, int vhostfdSize);
608 609 610 611 612

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

613
int qemuMonitorAddNetdev(qemuMonitorPtr mon,
614
                         const char *netdevstr,
615 616
                         int *tapfd, char **tapfdName, int tapfdSize,
                         int *vhostfd, char **vhostfdName, int vhostfdSize);
617 618 619 620

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

621 622
int qemuMonitorGetPtyPaths(qemuMonitorPtr mon,
                           virHashTablePtr paths);
623

624 625
int qemuMonitorAttachPCIDiskController(qemuMonitorPtr mon,
                                       const char *bus,
626
                                       virDevicePCIAddress *guestAddr);
627

628 629
int qemuMonitorAttachDrive(qemuMonitorPtr mon,
                           const char *drivestr,
630
                           virDevicePCIAddress *controllerAddr,
631 632
                           virDomainDeviceDriveAddress *driveAddr);

633 634 635 636 637

typedef struct _qemuMonitorPCIAddress qemuMonitorPCIAddress;
struct _qemuMonitorPCIAddress {
    unsigned int vendor;
    unsigned int product;
638
    virDevicePCIAddress addr;
639 640 641 642 643
};

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

644 645 646
int qemuMonitorAddDevice(qemuMonitorPtr mon,
                         const char *devicestr);

647 648 649 650 651
int qemuMonitorAddDeviceWithFd(qemuMonitorPtr mon,
                               const char *devicestr,
                               int fd,
                               const char *fdname);

652
int qemuMonitorDelDevice(qemuMonitorPtr mon,
653
                         const char *devalias);
654

655 656 657
int qemuMonitorAddDrive(qemuMonitorPtr mon,
                        const char *drivestr);

658
int qemuMonitorDriveDel(qemuMonitorPtr mon,
659 660
                        const char *drivestr);

661 662 663 664
int qemuMonitorSetDrivePassphrase(qemuMonitorPtr mon,
                                  const char *alias,
                                  const char *passphrase);

C
Chris Lalancette 已提交
665 666 667 668
int qemuMonitorCreateSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorLoadSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorDeleteSnapshot(qemuMonitorPtr mon, const char *name);

669
int qemuMonitorDiskSnapshot(qemuMonitorPtr mon,
670
                            virJSONValuePtr actions,
671
                            const char *device,
672 673 674
                            const char *file,
                            const char *format,
                            bool reuse);
675 676
int qemuMonitorTransaction(qemuMonitorPtr mon, virJSONValuePtr actions)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
677 678 679 680
int qemuMonitorDriveMirror(qemuMonitorPtr mon,
                           const char *device,
                           const char *file,
                           const char *format,
681
                           unsigned long long bandwidth,
682 683
                           unsigned int granularity,
                           unsigned long long buf_size,
684 685 686 687 688 689 690
                           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);
691

692 693 694 695
int qemuMonitorBlockCommit(qemuMonitorPtr mon,
                           const char *device,
                           const char *top,
                           const char *base,
696
                           const char *backingName,
697
                           unsigned long long bandwidth)
698 699
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
    ATTRIBUTE_NONNULL(4);
700
bool qemuMonitorSupportsActiveCommit(qemuMonitorPtr mon);
701

702 703 704 705
int qemuMonitorArbitraryCommand(qemuMonitorPtr mon,
                                const char *cmd,
                                char **reply,
                                bool hmp);
706

707 708
int qemuMonitorInjectNMI(qemuMonitorPtr mon);

709 710 711
int qemuMonitorScreendump(qemuMonitorPtr mon,
                          const char *file);

712 713 714 715 716
int qemuMonitorSendKey(qemuMonitorPtr mon,
                       unsigned int holdtime,
                       unsigned int *keycodes,
                       unsigned int nkeycodes);

717
typedef enum {
718 719 720 721
    BLOCK_JOB_ABORT,
    BLOCK_JOB_SPEED,
    BLOCK_JOB_PULL,
} qemuMonitorBlockJobCmd;
722 723 724

int qemuMonitorBlockJob(qemuMonitorPtr mon,
                        const char *device,
725 726
                        const char *base,
                        const char *backingName,
727
                        unsigned long long bandwidth,
728 729
                        qemuMonitorBlockJobCmd mode,
                        bool modern)
730
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
731

732 733
int qemuMonitorBlockJobInfo(qemuMonitorPtr mon,
                            const char *device,
734 735
                            virDomainBlockJobInfoPtr info,
                            unsigned long long *bandwidth)
736 737
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

738 739 740 741 742 743
int qemuMonitorOpenGraphics(qemuMonitorPtr mon,
                            const char *protocol,
                            int fd,
                            const char *fdname,
                            bool skipauth);

744 745 746 747 748 749 750 751
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
                                  const char *device,
                                  virDomainBlockIoTuneInfoPtr info);

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

752 753
int qemuMonitorSystemWakeup(qemuMonitorPtr mon);

754 755 756 757 758 759 760
int qemuMonitorGetVersion(qemuMonitorPtr mon,
                          int *major,
                          int *minor,
                          int *micro,
                          char **package)
    ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(4);

761 762 763 764 765 766 767 768

typedef struct _qemuMonitorMachineInfo qemuMonitorMachineInfo;
typedef qemuMonitorMachineInfo *qemuMonitorMachineInfoPtr;

struct _qemuMonitorMachineInfo {
    char *name;
    bool isDefault;
    char *alias;
769
    unsigned int maxCpus;
770 771 772 773 774 775 776
};

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

void qemuMonitorMachineInfoFree(qemuMonitorMachineInfoPtr machine);

777 778 779
int qemuMonitorGetCPUDefinitions(qemuMonitorPtr mon,
                                 char ***cpus);

780 781
int qemuMonitorGetCommands(qemuMonitorPtr mon,
                           char ***commands);
782 783
int qemuMonitorGetEvents(qemuMonitorPtr mon,
                         char ***events);
784 785
int qemuMonitorGetCommandLineOptionParameters(qemuMonitorPtr mon,
                                              const char *option,
786 787
                                              char ***params,
                                              bool *found);
788

789 790 791 792
int qemuMonitorGetKVMState(qemuMonitorPtr mon,
                           bool *enabled,
                           bool *present);

793 794
int qemuMonitorGetObjectTypes(qemuMonitorPtr mon,
                              char ***types);
795 796 797
int qemuMonitorGetObjectProps(qemuMonitorPtr mon,
                              const char *type,
                              char ***props);
798
char *qemuMonitorGetTargetArch(qemuMonitorPtr mon);
799

800 801 802
int qemuMonitorNBDServerStart(qemuMonitorPtr mon,
                              const char *host,
                              unsigned int port);
803 804 805
int qemuMonitorNBDServerAdd(qemuMonitorPtr mon,
                            const char *deviceID,
                            bool writable);
806
int qemuMonitorNBDServerStop(qemuMonitorPtr);
S
Stefan Berger 已提交
807 808 809 810 811 812
int qemuMonitorGetTPMModels(qemuMonitorPtr mon,
                            char ***tpmmodels);

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

813 814 815
int qemuMonitorAttachCharDev(qemuMonitorPtr mon,
                             const char *chrID,
                             virDomainChrSourceDefPtr chr);
816 817
int qemuMonitorDetachCharDev(qemuMonitorPtr mon,
                             const char *chrID);
818 819 820 821

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

822 823
int qemuMonitorSetDomainLog(qemuMonitorPtr mon, int logfd);

824 825 826
int qemuMonitorGetGuestCPU(qemuMonitorPtr mon,
                           virArch arch,
                           virCPUDataPtr *data);
827

828 829
int qemuMonitorRTCResetReinjection(qemuMonitorPtr mon);

830 831 832 833 834 835 836 837 838 839 840 841
typedef struct _qemuMonitorIOThreadsInfo qemuMonitorIOThreadsInfo;
typedef qemuMonitorIOThreadsInfo *qemuMonitorIOThreadsInfoPtr;

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

void qemuMonitorIOThreadsInfoFree(qemuMonitorIOThreadsInfoPtr iothread);

842 843 844 845 846 847 848 849 850 851 852 853 854
/**
 * 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

855
#endif /* QEMU_MONITOR_H */