qemu_domain.h 17.8 KB
Newer Older
1 2 3
/*
 * qemu_domain.h: QEMU domain private state
 *
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 26
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef __QEMU_DOMAIN_H__
# define __QEMU_DOMAIN_H__

27
# include "virthread.h"
28
# include "vircgroup.h"
29
# include "domain_addr.h"
30
# include "domain_conf.h"
31
# include "snapshot_conf.h"
32
# include "qemu_monitor.h"
D
Daniel P. Berrange 已提交
33
# include "qemu_agent.h"
34
# include "qemu_conf.h"
35
# include "qemu_capabilities.h"
36
# include "virchrdev.h"
37
# include "virobject.h"
38

39 40 41 42
# define QEMU_DOMAIN_FORMAT_LIVE_FLAGS      \
    (VIR_DOMAIN_XML_SECURE |                \
     VIR_DOMAIN_XML_UPDATE_CPU)

43 44 45
# if ULONG_MAX == 4294967295
/* Qemu has a 64-bit limit, but we are limited by our historical choice of
 * representing bandwidth in a long instead of a 64-bit int.  */
46
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX ULONG_MAX
47
# else
48
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX (INT64_MAX / (1024 * 1024))
49
# endif
50

51
# define JOB_MASK(job)                  (1 << (job - 1))
52
# define QEMU_JOB_DEFAULT_MASK          \
53 54 55
    (JOB_MASK(QEMU_JOB_QUERY) |         \
     JOB_MASK(QEMU_JOB_DESTROY) |       \
     JOB_MASK(QEMU_JOB_ABORT))
56

57 58 59 60 61
/* Jobs which have to be tracked in domain state XML. */
# define QEMU_DOMAIN_TRACK_JOBS         \
    (JOB_MASK(QEMU_JOB_DESTROY) |       \
     JOB_MASK(QEMU_JOB_ASYNC))

62 63 64
/* Only 1 job is allowed at any time
 * A job includes *all* monitor commands, even those just querying
 * information, not merely actions */
65
typedef enum {
66
    QEMU_JOB_NONE = 0,  /* Always set to 0 for easy if (jobActive) conditions */
67 68 69 70
    QEMU_JOB_QUERY,         /* Doesn't change any state */
    QEMU_JOB_DESTROY,       /* Destroys the domain (cannot be masked out) */
    QEMU_JOB_SUSPEND,       /* Suspends (stops vCPUs) the domain */
    QEMU_JOB_MODIFY,        /* May change state */
71
    QEMU_JOB_ABORT,         /* Abort current async job */
72
    QEMU_JOB_MIGRATION_OP,  /* Operation influencing outgoing migration */
73

74
    /* The following two items must always be the last items before JOB_LAST */
75 76
    QEMU_JOB_ASYNC,         /* Asynchronous job */
    QEMU_JOB_ASYNC_NESTED,  /* Normal job within an async job */
77 78

    QEMU_JOB_LAST
79
} qemuDomainJob;
80
VIR_ENUM_DECL(qemuDomainJob)
81 82 83 84 85

/* Async job consists of a series of jobs that may change state. Independent
 * jobs that do not change state (and possibly others if explicitly allowed by
 * current async job) are allowed to be run even if async job is active.
 */
86
typedef enum {
87 88 89 90 91
    QEMU_ASYNC_JOB_NONE = 0,
    QEMU_ASYNC_JOB_MIGRATION_OUT,
    QEMU_ASYNC_JOB_MIGRATION_IN,
    QEMU_ASYNC_JOB_SAVE,
    QEMU_ASYNC_JOB_DUMP,
92
    QEMU_ASYNC_JOB_SNAPSHOT,
93 94

    QEMU_ASYNC_JOB_LAST
95
} qemuDomainAsyncJob;
96
VIR_ENUM_DECL(qemuDomainAsyncJob)
97

J
Jiri Denemark 已提交
98 99 100 101 102
typedef struct _qemuDomainJobInfo qemuDomainJobInfo;
typedef qemuDomainJobInfo *qemuDomainJobInfoPtr;
struct _qemuDomainJobInfo {
    virDomainJobType type;
    unsigned long long started; /* When the async job started */
103
    unsigned long long stopped; /* When the domain's CPUs were stopped */
104 105 106 107
    unsigned long long sent; /* When the source sent status info to the
                                destination (only for migrations). */
    unsigned long long received; /* When the destination host received status
                                    info from the source (migrations only). */
J
Jiri Denemark 已提交
108 109 110
    /* Computed values */
    unsigned long long timeElapsed;
    unsigned long long timeRemaining;
J
Jiri Denemark 已提交
111
    long long timeDelta; /* delta = received - sent, i.e., the difference
112 113 114 115 116
                            between the source and the destination time plus
                            the time between the end of Perform phase on the
                            source and the beginning of Finish phase on the
                            destination. */
    bool timeDeltaSet;
J
Jiri Denemark 已提交
117 118 119 120
    /* Raw values from QEMU */
    qemuMonitorMigrationStatus status;
};

121
struct qemuDomainJobObj {
122
    virCond cond;                       /* Use to coordinate jobs */
123
    qemuDomainJob active;               /* Currently running job */
124
    unsigned long long owner;           /* Thread id which set current job */
125
    const char *ownerAPI;               /* The API which owns the job */
J
Jiri Denemark 已提交
126
    unsigned long long started;         /* When the current job started */
127

128
    virCond asyncCond;                  /* Use to coordinate with async jobs */
129
    qemuDomainAsyncJob asyncJob;        /* Currently active async job */
130
    unsigned long long asyncOwner;      /* Thread which set current async job */
131
    const char *asyncOwnerAPI;          /* The API which owns the async job */
J
Jiri Denemark 已提交
132
    unsigned long long asyncStarted;    /* When the current async job started */
J
Jiri Denemark 已提交
133
    int phase;                          /* Job phase (mainly for migrations) */
134
    unsigned long long mask;            /* Jobs allowed during async job */
135
    bool dump_memory_only;              /* use dump-guest-memory to do dump */
J
Jiri Denemark 已提交
136
    qemuDomainJobInfoPtr current;       /* async job progress data */
137
    qemuDomainJobInfoPtr completed;     /* statistics data of a recently completed job */
138
    bool abortJob;                      /* abort of the job requested */
139 140
};

141
typedef void (*qemuDomainCleanupCallback)(virQEMUDriverPtr driver,
142 143
                                          virDomainObjPtr vm);

144 145 146
typedef struct _qemuDomainObjPrivate qemuDomainObjPrivate;
typedef qemuDomainObjPrivate *qemuDomainObjPrivatePtr;
struct _qemuDomainObjPrivate {
147
    struct qemuDomainJobObj job;
148 149

    qemuMonitorPtr mon;
150
    virDomainChrSourceDefPtr monConfig;
E
Eric Blake 已提交
151
    bool monJSON;
152 153
    bool monError;
    unsigned long long monStart;
D
Daniel P. Berrange 已提交
154 155 156 157 158

    qemuAgentPtr agent;
    bool agentError;
    unsigned long long agentStart;

159
    bool gotShutdown;
160
    bool beingDestroyed;
161
    char *pidfile;
162 163 164 165

    int nvcpupids;
    int *vcpupids;

166
    virDomainPCIAddressSetPtr pciaddrs;
J
Ján Tomko 已提交
167
    virDomainCCWAddressSetPtr ccwaddrs;
168
    virDomainVirtioSerialAddrSetPtr vioserialaddrs;
169
    int persistentAddrs;
170

171
    virQEMUCapsPtr qemuCaps;
172
    char *lockState;
173 174

    bool fakeReboot;
175 176

    int jobs_queued;
177 178

    unsigned long migMaxBandwidth;
J
Jiri Denemark 已提交
179
    char *origname;
180
    int nbdPort; /* Port used for migration with NBD */
181
    unsigned short migrationPort;
182
    int preMigrationState;
183

184
    virChrdevsPtr devs;
185 186 187 188

    qemuDomainCleanupCallback *cleanupCallbacks;
    size_t ncleanupCallbacks;
    size_t ncleanupCallbacks_max;
189 190

    virCgroupPtr cgroup;
191 192 193

    virCond unplugFinished; /* signals that unpluggingDevice was unplugged */
    const char *unpluggingDevice; /* alias of the device that is being unplugged */
194
    char **qemuDevices; /* NULL-terminated list of devices aliases known to QEMU */
195 196

    bool hookRun;  /* true if there was a hook run over this domain */
197 198

    /* Bitmaps below hold data from the auto NUMA feature */
199
    virBitmapPtr autoNodeset;
200
    virBitmapPtr autoCpuset;
201 202
};

203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219
# define QEMU_DOMAIN_DISK_PRIVATE(disk)	\
    ((qemuDomainDiskPrivatePtr) (disk)->privateData)

typedef struct _qemuDomainDiskPrivate qemuDomainDiskPrivate;
typedef qemuDomainDiskPrivate *qemuDomainDiskPrivatePtr;
struct _qemuDomainDiskPrivate {
    virObject parent;

    /* ideally we want a smarter way to interlock block jobs on single qemu disk
     * in the future, but for now we just disallow any concurrent job on a
     * single disk */
    bool blockjob;

    /* for some synchronous block jobs, we need to notify the owner */
    int blockJobType;   /* type of the block job from the event */
    int blockJobStatus; /* status of the finished block job */
    bool blockJobSync; /* the block job needs synchronized termination */
220 221

    bool migrating; /* the disk is being migrated */
222 223
};

C
Chen Fan 已提交
224 225
typedef enum {
    QEMU_PROCESS_EVENT_WATCHDOG = 0,
226
    QEMU_PROCESS_EVENT_GUESTPANIC,
227
    QEMU_PROCESS_EVENT_DEVICE_DELETED,
228
    QEMU_PROCESS_EVENT_NIC_RX_FILTER_CHANGED,
229
    QEMU_PROCESS_EVENT_SERIAL_CHANGED,
230
    QEMU_PROCESS_EVENT_BLOCK_JOB,
C
Chen Fan 已提交
231 232 233 234 235

    QEMU_PROCESS_EVENT_LAST
} qemuProcessEventType;

struct qemuProcessEvent {
236
    virDomainObjPtr vm;
C
Chen Fan 已提交
237
    qemuProcessEventType eventType;
238
    int action;
239
    int status;
240
    void *data;
241 242
};

243
const char *qemuDomainAsyncJobPhaseToString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
244
                                            int phase);
245
int qemuDomainAsyncJobPhaseFromString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
246 247
                                      const char *phase);

248
void qemuDomainEventFlush(int timer, void *opaque);
249

250
void qemuDomainEventQueue(virQEMUDriverPtr driver,
251
                          virObjectEventPtr event);
252

253
int qemuDomainObjBeginJob(virQEMUDriverPtr driver,
254
                          virDomainObjPtr obj,
255
                          qemuDomainJob job)
256
    ATTRIBUTE_RETURN_CHECK;
257
int qemuDomainObjBeginAsyncJob(virQEMUDriverPtr driver,
258
                               virDomainObjPtr obj,
259
                               qemuDomainAsyncJob asyncJob)
260 261
    ATTRIBUTE_RETURN_CHECK;

262 263 264 265
void qemuDomainObjEndJob(virQEMUDriverPtr driver,
                         virDomainObjPtr obj);
void qemuDomainObjEndAsyncJob(virQEMUDriverPtr driver,
                              virDomainObjPtr obj);
266
void qemuDomainObjAbortAsyncJob(virDomainObjPtr obj);
267
void qemuDomainObjSetJobPhase(virQEMUDriverPtr driver,
J
Jiri Denemark 已提交
268 269
                              virDomainObjPtr obj,
                              int phase);
270 271
void qemuDomainObjSetAsyncJobMask(virDomainObjPtr obj,
                                  unsigned long long allowedJobs);
272 273
void qemuDomainObjRestoreJob(virDomainObjPtr obj,
                             struct qemuDomainJobObj *job);
274
void qemuDomainObjDiscardAsyncJob(virQEMUDriverPtr driver,
275
                                  virDomainObjPtr obj);
276
void qemuDomainObjReleaseAsyncJob(virDomainObjPtr obj);
277

278 279
qemuMonitorPtr qemuDomainGetMonitor(virDomainObjPtr vm)
    ATTRIBUTE_NONNULL(1);
280
void qemuDomainObjEnterMonitor(virQEMUDriverPtr driver,
281 282
                               virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
283 284
int qemuDomainObjExitMonitor(virQEMUDriverPtr driver,
                             virDomainObjPtr obj)
285 286
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
    ATTRIBUTE_RETURN_CHECK;
287
int qemuDomainObjEnterMonitorAsync(virQEMUDriverPtr driver,
288
                                   virDomainObjPtr obj,
289
                                   qemuDomainAsyncJob asyncJob)
290
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
291 292


293 294 295 296
void qemuDomainObjEnterAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
D
Daniel P. Berrange 已提交
297 298


299 300 301 302
void qemuDomainObjEnterRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
303

304 305 306 307
virDomainDefPtr qemuDomainDefCopy(virQEMUDriverPtr driver,
                                  virDomainDefPtr src,
                                  unsigned int flags);

308
int qemuDomainDefFormatBuf(virQEMUDriverPtr driver,
309 310 311 312
                           virDomainDefPtr vm,
                           unsigned int flags,
                           virBuffer *buf);

313
char *qemuDomainDefFormatXML(virQEMUDriverPtr driver,
314
                             virDomainDefPtr vm,
315
                             unsigned int flags);
316

317
char *qemuDomainFormatXML(virQEMUDriverPtr driver,
318
                          virDomainObjPtr vm,
319
                          unsigned int flags);
320

321
char *qemuDomainDefFormatLive(virQEMUDriverPtr driver,
322
                              virDomainDefPtr def,
323 324
                              bool inactive,
                              bool compatible);
325

326
void qemuDomainObjTaint(virQEMUDriverPtr driver,
327
                        virDomainObjPtr obj,
328
                        virDomainTaintFlags taint,
329
                        int logFD);
330

331
void qemuDomainObjCheckTaint(virQEMUDriverPtr driver,
332 333
                             virDomainObjPtr obj,
                             int logFD);
334
void qemuDomainObjCheckDiskTaint(virQEMUDriverPtr driver,
335
                                 virDomainObjPtr obj,
336 337
                                 virDomainDiskDefPtr disk,
                                 int logFD);
338 339 340 341
void qemuDomainObjCheckHostdevTaint(virQEMUDriverPtr driver,
                                    virDomainObjPtr obj,
                                    virDomainHostdevDefPtr disk,
                                    int logFD);
342
void qemuDomainObjCheckNetTaint(virQEMUDriverPtr driver,
343
                                virDomainObjPtr obj,
344 345
                                virDomainNetDefPtr net,
                                int logFD);
346

347

348 349 350
int qemuDomainCreateLog(virQEMUDriverPtr driver, virDomainObjPtr vm, bool append);
int qemuDomainOpenLog(virQEMUDriverPtr driver, virDomainObjPtr vm, off_t pos);
int qemuDomainAppendLog(virQEMUDriverPtr driver,
351 352 353
                        virDomainObjPtr vm,
                        int logFD,
                        const char *fmt, ...) ATTRIBUTE_FMT_PRINTF(4, 5);
354

355
const char *qemuFindQemuImgBinary(virQEMUDriverPtr driver);
356 357 358 359 360

int qemuDomainSnapshotWriteMetadata(virDomainObjPtr vm,
                                    virDomainSnapshotObjPtr snapshot,
                                    char *snapshotDir);

361
int qemuDomainSnapshotForEachQcow2(virQEMUDriverPtr driver,
362 363 364 365 366
                                   virDomainObjPtr vm,
                                   virDomainSnapshotObjPtr snap,
                                   const char *op,
                                   bool try_all);

367
int qemuDomainSnapshotDiscard(virQEMUDriverPtr driver,
368 369 370 371 372
                              virDomainObjPtr vm,
                              virDomainSnapshotObjPtr snap,
                              bool update_current,
                              bool metadata_only);

373 374 375
typedef struct _virQEMUSnapRemove virQEMUSnapRemove;
typedef virQEMUSnapRemove *virQEMUSnapRemovePtr;
struct _virQEMUSnapRemove {
376
    virQEMUDriverPtr driver;
377 378 379 380 381 382 383 384 385 386
    virDomainObjPtr vm;
    int err;
    bool metadata_only;
    bool current;
};

void qemuDomainSnapshotDiscardAll(void *payload,
                                  const void *name,
                                  void *data);

387
int qemuDomainSnapshotDiscardAllMetadata(virQEMUDriverPtr driver,
388 389
                                         virDomainObjPtr vm);

390
void qemuDomainRemoveInactive(virQEMUDriverPtr driver,
391 392
                              virDomainObjPtr vm);

393
void qemuDomainSetFakeReboot(virQEMUDriverPtr driver,
394 395 396
                             virDomainObjPtr vm,
                             bool value);

397
bool qemuDomainJobAllowed(qemuDomainObjPrivatePtr priv,
398
                          qemuDomainJob job);
M
Michal Privoznik 已提交
399

400
int qemuDomainCheckDiskPresence(virQEMUDriverPtr driver,
M
Michal Privoznik 已提交
401 402
                                virDomainObjPtr vm,
                                bool start_with_state);
403

404
int qemuDomainDetermineDiskChain(virQEMUDriverPtr driver,
405
                                 virDomainObjPtr vm,
406
                                 virDomainDiskDefPtr disk,
407 408
                                 bool force_probe,
                                 bool report_broken);
409

410 411 412
int qemuDomainStorageFileInit(virQEMUDriverPtr driver,
                              virDomainObjPtr vm,
                              virStorageSourcePtr src);
413
char *qemuDomainStorageAlias(const char *device, int depth);
414

415 416 417 418
int qemuDomainCleanupAdd(virDomainObjPtr vm,
                         qemuDomainCleanupCallback cb);
void qemuDomainCleanupRemove(virDomainObjPtr vm,
                             qemuDomainCleanupCallback cb);
419
void qemuDomainCleanupRun(virQEMUDriverPtr driver,
420 421
                          virDomainObjPtr vm);

422 423
extern virDomainXMLPrivateDataCallbacks virQEMUDriverPrivateDataCallbacks;
extern virDomainXMLNamespace virQEMUDriverDomainXMLNamespace;
424
extern virDomainDefParserConfig virQEMUDriverDomainDefParserConfig;
425

426
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
427
                               virDomainObjPtr vm, int asyncJob);
428

429 430 431 432
int qemuDomainUpdateMemoryDeviceInfo(virQEMUDriverPtr driver,
                                     virDomainObjPtr vm,
                                     int asyncJob);

433 434 435
bool qemuDomainDefCheckABIStability(virQEMUDriverPtr driver,
                                    virDomainDefPtr src,
                                    virDomainDefPtr dst);
436

437
bool qemuDomainAgentAvailable(virDomainObjPtr vm,
438 439
                              bool reportError);

J
Jiri Denemark 已提交
440 441
int qemuDomainJobInfoUpdateTime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
442 443
int qemuDomainJobInfoUpdateDowntime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
J
Jiri Denemark 已提交
444 445 446 447 448 449 450 451 452 453
int qemuDomainJobInfoToInfo(qemuDomainJobInfoPtr jobInfo,
                            virDomainJobInfoPtr info)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
int qemuDomainJobInfoToParams(qemuDomainJobInfoPtr jobInfo,
                              int *type,
                              virTypedParameterPtr *params,
                              int *nparams)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
    ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(4);

454 455
int qemuDomainSupportsBlockJobs(virDomainObjPtr vm, bool *modern)
    ATTRIBUTE_NONNULL(1);
456
bool qemuDomainDiskBlockJobIsActive(virDomainDiskDefPtr disk);
457 458
bool qemuDomainHasBlockjob(virDomainObjPtr vm, bool copy_only)
    ATTRIBUTE_NONNULL(1);
459

460
int qemuDomainAlignMemorySizes(virDomainDefPtr def);
461
void qemuDomainMemoryDeviceAlignSize(virDomainMemoryDefPtr mem);
462

463 464
virDomainChrSourceDefPtr qemuFindAgentConfig(virDomainDefPtr def);

465 466 467
bool qemuDomainMachineIsQ35(const virDomainDef *def);
bool qemuDomainMachineIsI440FX(const virDomainDef *def);

468 469 470
int qemuDomainUpdateCurrentMemorySize(virQEMUDriverPtr driver,
                                      virDomainObjPtr vm);

471
#endif /* __QEMU_DOMAIN_H__ */