qemu_monitor.h 17.6 KB
Newer Older
1 2 3
/*
 * qemu_monitor.h: interaction with QEMU monitor console
 *
4
 * Copyright (C) 2006-2011 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
 * 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
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */


#ifndef QEMU_MONITOR_H
26
# define QEMU_MONITOR_H
27

28
# include "internal.h"
29

30 31
# include "domain_conf.h"
# include "hash.h"
32

33 34
typedef struct _qemuMonitor qemuMonitor;
typedef qemuMonitor *qemuMonitorPtr;
35

36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
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;

52
    /* Used by the text monitor reply / error */
53 54
    char *rxBuffer;
    int rxLength;
55 56
    /* Used by the JSON monitor to hold reply / error */
    void *rxObject;
57

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

    qemuMonitorPasswordHandler passwordHandler;
    void *passwordOpaque;
};

67 68 69
typedef struct _qemuMonitorCallbacks qemuMonitorCallbacks;
typedef qemuMonitorCallbacks *qemuMonitorCallbacksPtr;
struct _qemuMonitorCallbacks {
70 71 72
    void (*destroy)(qemuMonitorPtr mon,
                    virDomainObjPtr vm);

73
    void (*eofNotify)(qemuMonitorPtr mon,
74 75 76 77
                      virDomainObjPtr vm);
    void (*errorNotify)(qemuMonitorPtr mon,
                        virDomainObjPtr vm);
    /* XXX we'd really like to avoid virConnectPtr here
78 79 80 81 82 83 84 85 86 87
     * 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);
88 89 90 91 92 93 94 95 96

    int (*domainShutdown)(qemuMonitorPtr mon,
                          virDomainObjPtr vm);
    int (*domainReset)(qemuMonitorPtr mon,
                       virDomainObjPtr vm);
    int (*domainPowerdown)(qemuMonitorPtr mon,
                           virDomainObjPtr vm);
    int (*domainStop)(qemuMonitorPtr mon,
                      virDomainObjPtr vm);
97 98 99
    int (*domainRTCChange)(qemuMonitorPtr mon,
                           virDomainObjPtr vm,
                           long long offset);
100 101 102
    int (*domainWatchdog)(qemuMonitorPtr mon,
                          virDomainObjPtr vm,
                          int action);
103 104 105
    int (*domainIOError)(qemuMonitorPtr mon,
                         virDomainObjPtr vm,
                         const char *diskAlias,
106 107
                         int action,
                         const char *reason);
108 109 110 111 112 113 114 115 116 117 118 119
    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);
120 121 122 123
    int (*domainBlockPull)(qemuMonitorPtr mon,
                           virDomainObjPtr vm,
                           const char *diskAlias,
                           int status);
124 125
};

126

127 128 129
char *qemuMonitorEscapeArg(const char *in);
char *qemuMonitorEscapeShell(const char *in);

130
qemuMonitorPtr qemuMonitorOpen(virDomainObjPtr vm,
131
                               virDomainChrSourceDefPtr config,
D
Daniel P. Berrange 已提交
132
                               int json,
133
                               qemuMonitorCallbacksPtr cb);
134

135
void qemuMonitorClose(qemuMonitorPtr mon);
136

137 138
int qemuMonitorSetCapabilities(qemuMonitorPtr mon);

139 140
int qemuMonitorCheckHMP(qemuMonitorPtr mon, const char *cmd);

141 142 143
void qemuMonitorLock(qemuMonitorPtr mon);
void qemuMonitorUnlock(qemuMonitorPtr mon);

144
int qemuMonitorRef(qemuMonitorPtr mon);
145
int qemuMonitorUnref(qemuMonitorPtr mon) ATTRIBUTE_RETURN_CHECK;
146

147
/* These APIs are for use by the internal Text/JSON monitor impl code only */
148
char *qemuMonitorNextCommandID(qemuMonitorPtr mon);
149 150
int qemuMonitorSend(qemuMonitorPtr mon,
                    qemuMonitorMessagePtr msg);
151 152 153 154 155 156
int qemuMonitorHMPCommandWithFd(qemuMonitorPtr mon,
                                const char *cmd,
                                int scm_fd,
                                char **reply);
# define qemuMonitorHMPCommand(mon, cmd, reply) \
    qemuMonitorHMPCommandWithFd(mon, cmd, -1, reply)
157

158
/* XXX same comment about virConnectPtr as above */
159 160 161 162 163
int qemuMonitorGetDiskSecret(qemuMonitorPtr mon,
                             virConnectPtr conn,
                             const char *path,
                             char **secret,
                             size_t *secretLen);
164

165 166 167 168
int qemuMonitorEmitShutdown(qemuMonitorPtr mon);
int qemuMonitorEmitReset(qemuMonitorPtr mon);
int qemuMonitorEmitPowerdown(qemuMonitorPtr mon);
int qemuMonitorEmitStop(qemuMonitorPtr mon);
169
int qemuMonitorEmitRTCChange(qemuMonitorPtr mon, long long offset);
170
int qemuMonitorEmitWatchdog(qemuMonitorPtr mon, int action);
171 172
int qemuMonitorEmitIOError(qemuMonitorPtr mon,
                           const char *diskAlias,
173 174
                           int action,
                           const char *reason);
175 176 177 178 179 180 181 182 183 184 185
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);
186 187 188 189
int qemuMonitorEmitBlockPull(qemuMonitorPtr mon,
                             const char *diskAlias,
                             int status);

190

191 192 193 194

int qemuMonitorStartCPUs(qemuMonitorPtr mon,
                         virConnectPtr conn);
int qemuMonitorStopCPUs(qemuMonitorPtr mon);
195
int qemuMonitorGetStatus(qemuMonitorPtr mon, bool *running);
196 197 198 199 200 201 202

int qemuMonitorSystemPowerdown(qemuMonitorPtr mon);

int qemuMonitorGetCPUInfo(qemuMonitorPtr mon,
                          int **pids);
int qemuMonitorGetBalloonInfo(qemuMonitorPtr mon,
                              unsigned long *currmem);
203 204 205
int qemuMonitorGetMemoryStats(qemuMonitorPtr mon,
                              virDomainMemoryStatPtr stats,
                              unsigned int nr_stats);
206 207 208 209 210 211 212 213
int qemuMonitorGetBlockStatsInfo(qemuMonitorPtr mon,
                                 const char *devname,
                                 long long *rd_req,
                                 long long *rd_bytes,
                                 long long *wr_req,
                                 long long *wr_bytes,
                                 long long *errs);

214 215 216 217
int qemuMonitorGetBlockExtent(qemuMonitorPtr mon,
                              const char *devname,
                              unsigned long long *extent);

218 219 220

int qemuMonitorSetVNCPassword(qemuMonitorPtr mon,
                              const char *password);
221 222 223 224 225 226 227
int qemuMonitorSetPassword(qemuMonitorPtr mon,
                           int type,
                           const char *password,
                           const char *action_if_connected);
int qemuMonitorExpirePassword(qemuMonitorPtr mon,
                              int type,
                              const char *expire_time);
228 229
int qemuMonitorSetBalloon(qemuMonitorPtr mon,
                          unsigned long newmem);
230 231
int qemuMonitorSetCPU(qemuMonitorPtr mon, int cpu, int online);

232 233 234 235 236 237

/* XXX should we pass the virDomainDiskDefPtr instead
 * and hide devname details inside monitor. Reconsider
 * this when doing the QMP implementation
 */
int qemuMonitorEjectMedia(qemuMonitorPtr mon,
238 239
                          const char *devname,
                          bool force);
240 241
int qemuMonitorChangeMedia(qemuMonitorPtr mon,
                           const char *devname,
242 243
                           const char *newmedia,
                           const char *format);
244 245 246 247 248 249 250 251 252 253 254 255 256 257


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

258 259 260
int qemuMonitorSetMigrationDowntime(qemuMonitorPtr mon,
                                    unsigned long long downtime);

261 262 263 264 265 266 267 268 269 270
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
};

271 272
VIR_ENUM_DECL(qemuMonitorMigrationStatus)

273 274 275 276 277 278
int qemuMonitorGetMigrationStatus(qemuMonitorPtr mon,
                                  int *status,
                                  unsigned long long *transferred,
                                  unsigned long long *remaining,
                                  unsigned long long *total);

279
typedef enum {
E
Eric Blake 已提交
280
  QEMU_MONITOR_MIGRATE_BACKGROUND	= 1 << 0,
281 282 283 284 285
  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 已提交
286 287 288 289
int qemuMonitorMigrateToFd(qemuMonitorPtr mon,
                           unsigned int flags,
                           int fd);

290
int qemuMonitorMigrateToHost(qemuMonitorPtr mon,
291
                             unsigned int flags,
292 293 294 295
                             const char *hostname,
                             int port);

int qemuMonitorMigrateToCommand(qemuMonitorPtr mon,
296
                                unsigned int flags,
297 298
                                const char * const *argv);

299 300 301 302 303 304 305
/* 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.
306
 */
307 308
# define QEMU_MONITOR_MIGRATE_TO_FILE_BS (1024llu * 4)
# define QEMU_MONITOR_MIGRATE_TO_FILE_TRANSFER_SIZE (1024llu * 1024)
309 310

int qemuMonitorMigrateToFile(qemuMonitorPtr mon,
311
                             unsigned int flags,
312 313 314
                             const char * const *argv,
                             const char *target,
                             unsigned long long offset);
315 316

int qemuMonitorMigrateToUnix(qemuMonitorPtr mon,
317
                             unsigned int flags,
318 319 320 321
                             const char *unixfile);

int qemuMonitorMigrateCancel(qemuMonitorPtr mon);

322 323 324 325 326 327
int qemuMonitorGraphicsRelocate(qemuMonitorPtr mon,
                                int type,
                                const char *hostname,
                                int port,
                                int tlsPort,
                                const char *tlsSubject);
328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343

/* 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,
344 345
                                virDomainDevicePCIAddress *hostAddr,
                                virDomainDevicePCIAddress *guestAddr);
346 347 348 349 350 351 352

/* XXX disk driver type eg,  qcow/etc.
 * XXX cache mode
 */
int qemuMonitorAddPCIDisk(qemuMonitorPtr mon,
                          const char *path,
                          const char *bus,
353
                          virDomainDevicePCIAddress *guestAddr);
354 355 356 357 358 359

/* XXX do we really want to hardcode 'nicstr' as the
 * sendable item here
 */
int qemuMonitorAddPCINetwork(qemuMonitorPtr mon,
                             const char *nicstr,
360
                             virDomainDevicePCIAddress *guestAddr);
361 362

int qemuMonitorRemovePCIDevice(qemuMonitorPtr mon,
363
                               virDomainDevicePCIAddress *guestAddr);
364 365 366 367 368 369 370 371 372 373 374 375 376 377


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

int qemuMonitorCloseFileHandle(qemuMonitorPtr mon,
                               const char *fdname);


/* XXX do we really want to hardcode 'netstr' as the
 * sendable item here
 */
int qemuMonitorAddHostNetwork(qemuMonitorPtr mon,
378 379 380
                              const char *netstr,
                              int tapfd, const char *tapfd_name,
                              int vhostfd, const char *vhostfd_name);
381 382 383 384 385

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

386
int qemuMonitorAddNetdev(qemuMonitorPtr mon,
387 388 389
                         const char *netdevstr,
                         int tapfd, const char *tapfd_name,
                         int vhostfd, const char *vhostfd_name);
390 391 392 393

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

394 395
int qemuMonitorGetPtyPaths(qemuMonitorPtr mon,
                           virHashTablePtr paths);
396

397 398 399 400
int qemuMonitorAttachPCIDiskController(qemuMonitorPtr mon,
                                       const char *bus,
                                       virDomainDevicePCIAddress *guestAddr);

401 402 403 404 405
int qemuMonitorAttachDrive(qemuMonitorPtr mon,
                           const char *drivestr,
                           virDomainDevicePCIAddress *controllerAddr,
                           virDomainDeviceDriveAddress *driveAddr);

406 407 408 409 410 411 412 413 414 415 416

typedef struct _qemuMonitorPCIAddress qemuMonitorPCIAddress;
struct _qemuMonitorPCIAddress {
    unsigned int vendor;
    unsigned int product;
    virDomainDevicePCIAddress addr;
};

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

417 418 419
int qemuMonitorAddDevice(qemuMonitorPtr mon,
                         const char *devicestr);

420 421 422 423 424
int qemuMonitorAddDeviceWithFd(qemuMonitorPtr mon,
                               const char *devicestr,
                               int fd,
                               const char *fdname);

425
int qemuMonitorDelDevice(qemuMonitorPtr mon,
426
                         const char *devalias);
427

428 429 430
int qemuMonitorAddDrive(qemuMonitorPtr mon,
                        const char *drivestr);

431
int qemuMonitorDriveDel(qemuMonitorPtr mon,
432 433
                        const char *drivestr);

434 435 436 437
int qemuMonitorSetDrivePassphrase(qemuMonitorPtr mon,
                                  const char *alias,
                                  const char *passphrase);

C
Chris Lalancette 已提交
438 439 440 441
int qemuMonitorCreateSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorLoadSnapshot(qemuMonitorPtr mon, const char *name);
int qemuMonitorDeleteSnapshot(qemuMonitorPtr mon, const char *name);

442 443 444 445
int qemuMonitorArbitraryCommand(qemuMonitorPtr mon,
                                const char *cmd,
                                char **reply,
                                bool hmp);
446

447 448
int qemuMonitorInjectNMI(qemuMonitorPtr mon);

449 450 451
int qemuMonitorScreendump(qemuMonitorPtr mon,
                          const char *file);

452 453 454 455 456 457 458 459 460 461 462 463 464
typedef enum {
    BLOCK_PULL_MODE_ONE = 0,
    BLOCK_PULL_MODE_ALL = 1,
    BLOCK_PULL_MODE_ABORT = 2,
    BLOCK_PULL_MODE_INFO = 3,
} BLOCK_PULL_MODE;


int qemuMonitorBlockPull(qemuMonitorPtr mon,
                         const char *path,
                         virDomainBlockPullInfoPtr info,
                         int mode);

465 466 467 468 469 470 471 472 473 474 475 476 477
/**
 * 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

478
#endif /* QEMU_MONITOR_H */