qemu_domain.h 16.7 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

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

42 43 44
# 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.  */
45
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX ULONG_MAX
46
# else
47
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX (INT64_MAX / (1024 * 1024))
48
# endif
49

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

56 57 58 59 60
/* 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))

61 62 63
/* Only 1 job is allowed at any time
 * A job includes *all* monitor commands, even those just querying
 * information, not merely actions */
64
typedef enum {
65
    QEMU_JOB_NONE = 0,  /* Always set to 0 for easy if (jobActive) conditions */
66 67 68 69
    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 */
70
    QEMU_JOB_ABORT,         /* Abort current async job */
71
    QEMU_JOB_MIGRATION_OP,  /* Operation influencing outgoing migration */
72

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

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

/* 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.
 */
85
typedef enum {
86 87 88 89 90
    QEMU_ASYNC_JOB_NONE = 0,
    QEMU_ASYNC_JOB_MIGRATION_OUT,
    QEMU_ASYNC_JOB_MIGRATION_IN,
    QEMU_ASYNC_JOB_SAVE,
    QEMU_ASYNC_JOB_DUMP,
91
    QEMU_ASYNC_JOB_SNAPSHOT,
92 93

    QEMU_ASYNC_JOB_LAST
94
} qemuDomainAsyncJob;
95
VIR_ENUM_DECL(qemuDomainAsyncJob)
96

J
Jiri Denemark 已提交
97 98 99 100 101
typedef struct _qemuDomainJobInfo qemuDomainJobInfo;
typedef qemuDomainJobInfo *qemuDomainJobInfoPtr;
struct _qemuDomainJobInfo {
    virDomainJobType type;
    unsigned long long started; /* When the async job started */
102
    unsigned long long stopped; /* When the domain's CPUs were stopped */
103 104 105 106
    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 已提交
107 108 109
    /* Computed values */
    unsigned long long timeElapsed;
    unsigned long long timeRemaining;
J
Jiri Denemark 已提交
110
    long long timeDelta; /* delta = received - sent, i.e., the difference
111 112 113 114 115
                            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 已提交
116 117 118 119
    /* Raw values from QEMU */
    qemuMonitorMigrationStatus status;
};

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

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

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

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

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

    qemuAgentPtr agent;
    bool agentError;
    unsigned long long agentStart;

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

    int nvcpupids;
    int *vcpupids;

165 166 167
    int niothreadpids;
    int *iothreadpids;

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

173
    virQEMUCapsPtr qemuCaps;
174
    char *lockState;
175 176

    bool fakeReboot;
177 178

    int jobs_queued;
179 180

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

186
    virChrdevsPtr devs;
187 188 189 190

    qemuDomainCleanupCallback *cleanupCallbacks;
    size_t ncleanupCallbacks;
    size_t ncleanupCallbacks_max;
191 192

    virCgroupPtr cgroup;
193 194 195

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

    bool hookRun;  /* true if there was a hook run over this domain */
199 200

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

C
Chen Fan 已提交
205 206
typedef enum {
    QEMU_PROCESS_EVENT_WATCHDOG = 0,
207
    QEMU_PROCESS_EVENT_GUESTPANIC,
208
    QEMU_PROCESS_EVENT_DEVICE_DELETED,
209
    QEMU_PROCESS_EVENT_NIC_RX_FILTER_CHANGED,
210
    QEMU_PROCESS_EVENT_SERIAL_CHANGED,
211
    QEMU_PROCESS_EVENT_BLOCK_JOB,
C
Chen Fan 已提交
212 213 214 215 216

    QEMU_PROCESS_EVENT_LAST
} qemuProcessEventType;

struct qemuProcessEvent {
217
    virDomainObjPtr vm;
C
Chen Fan 已提交
218
    qemuProcessEventType eventType;
219
    int action;
220
    int status;
221
    void *data;
222 223
};

224
const char *qemuDomainAsyncJobPhaseToString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
225
                                            int phase);
226
int qemuDomainAsyncJobPhaseFromString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
227 228
                                      const char *phase);

229
void qemuDomainEventFlush(int timer, void *opaque);
230

231
void qemuDomainEventQueue(virQEMUDriverPtr driver,
232
                          virObjectEventPtr event);
233

234
int qemuDomainObjBeginJob(virQEMUDriverPtr driver,
235
                          virDomainObjPtr obj,
236
                          qemuDomainJob job)
237
    ATTRIBUTE_RETURN_CHECK;
238
int qemuDomainObjBeginAsyncJob(virQEMUDriverPtr driver,
239
                               virDomainObjPtr obj,
240
                               qemuDomainAsyncJob asyncJob)
241 242
    ATTRIBUTE_RETURN_CHECK;

243 244 245 246
void qemuDomainObjEndJob(virQEMUDriverPtr driver,
                         virDomainObjPtr obj);
void qemuDomainObjEndAsyncJob(virQEMUDriverPtr driver,
                              virDomainObjPtr obj);
247
void qemuDomainObjAbortAsyncJob(virDomainObjPtr obj);
248
void qemuDomainObjSetJobPhase(virQEMUDriverPtr driver,
J
Jiri Denemark 已提交
249 250
                              virDomainObjPtr obj,
                              int phase);
251 252
void qemuDomainObjSetAsyncJobMask(virDomainObjPtr obj,
                                  unsigned long long allowedJobs);
253 254
void qemuDomainObjRestoreJob(virDomainObjPtr obj,
                             struct qemuDomainJobObj *job);
255
void qemuDomainObjDiscardAsyncJob(virQEMUDriverPtr driver,
256
                                  virDomainObjPtr obj);
257
void qemuDomainObjReleaseAsyncJob(virDomainObjPtr obj);
258

259 260
qemuMonitorPtr qemuDomainGetMonitor(virDomainObjPtr vm)
    ATTRIBUTE_NONNULL(1);
261
void qemuDomainObjEnterMonitor(virQEMUDriverPtr driver,
262 263
                               virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
264 265
int qemuDomainObjExitMonitor(virQEMUDriverPtr driver,
                             virDomainObjPtr obj)
266 267
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
    ATTRIBUTE_RETURN_CHECK;
268
int qemuDomainObjEnterMonitorAsync(virQEMUDriverPtr driver,
269
                                   virDomainObjPtr obj,
270
                                   qemuDomainAsyncJob asyncJob)
271
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
272 273


274 275 276 277
void qemuDomainObjEnterAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
D
Daniel P. Berrange 已提交
278 279


280 281 282 283
void qemuDomainObjEnterRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
284

285 286 287 288
virDomainDefPtr qemuDomainDefCopy(virQEMUDriverPtr driver,
                                  virDomainDefPtr src,
                                  unsigned int flags);

289
int qemuDomainDefFormatBuf(virQEMUDriverPtr driver,
290 291 292 293
                           virDomainDefPtr vm,
                           unsigned int flags,
                           virBuffer *buf);

294
char *qemuDomainDefFormatXML(virQEMUDriverPtr driver,
295
                             virDomainDefPtr vm,
296
                             unsigned int flags);
297

298
char *qemuDomainFormatXML(virQEMUDriverPtr driver,
299
                          virDomainObjPtr vm,
300
                          unsigned int flags);
301

302
char *qemuDomainDefFormatLive(virQEMUDriverPtr driver,
303
                              virDomainDefPtr def,
304 305
                              bool inactive,
                              bool compatible);
306

307
void qemuDomainObjTaint(virQEMUDriverPtr driver,
308
                        virDomainObjPtr obj,
309
                        virDomainTaintFlags taint,
310
                        int logFD);
311

312
void qemuDomainObjCheckTaint(virQEMUDriverPtr driver,
313 314
                             virDomainObjPtr obj,
                             int logFD);
315
void qemuDomainObjCheckDiskTaint(virQEMUDriverPtr driver,
316
                                 virDomainObjPtr obj,
317 318
                                 virDomainDiskDefPtr disk,
                                 int logFD);
319 320 321 322
void qemuDomainObjCheckHostdevTaint(virQEMUDriverPtr driver,
                                    virDomainObjPtr obj,
                                    virDomainHostdevDefPtr disk,
                                    int logFD);
323
void qemuDomainObjCheckNetTaint(virQEMUDriverPtr driver,
324
                                virDomainObjPtr obj,
325 326
                                virDomainNetDefPtr net,
                                int logFD);
327

328

329 330 331
int qemuDomainCreateLog(virQEMUDriverPtr driver, virDomainObjPtr vm, bool append);
int qemuDomainOpenLog(virQEMUDriverPtr driver, virDomainObjPtr vm, off_t pos);
int qemuDomainAppendLog(virQEMUDriverPtr driver,
332 333 334
                        virDomainObjPtr vm,
                        int logFD,
                        const char *fmt, ...) ATTRIBUTE_FMT_PRINTF(4, 5);
335

336
const char *qemuFindQemuImgBinary(virQEMUDriverPtr driver);
337 338 339 340 341

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

342
int qemuDomainSnapshotForEachQcow2(virQEMUDriverPtr driver,
343 344 345 346 347
                                   virDomainObjPtr vm,
                                   virDomainSnapshotObjPtr snap,
                                   const char *op,
                                   bool try_all);

348
int qemuDomainSnapshotDiscard(virQEMUDriverPtr driver,
349 350 351 352 353
                              virDomainObjPtr vm,
                              virDomainSnapshotObjPtr snap,
                              bool update_current,
                              bool metadata_only);

354 355 356
typedef struct _virQEMUSnapRemove virQEMUSnapRemove;
typedef virQEMUSnapRemove *virQEMUSnapRemovePtr;
struct _virQEMUSnapRemove {
357
    virQEMUDriverPtr driver;
358 359 360 361 362 363 364 365 366 367
    virDomainObjPtr vm;
    int err;
    bool metadata_only;
    bool current;
};

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

368
int qemuDomainSnapshotDiscardAllMetadata(virQEMUDriverPtr driver,
369 370
                                         virDomainObjPtr vm);

371
void qemuDomainRemoveInactive(virQEMUDriverPtr driver,
372 373
                              virDomainObjPtr vm);

374
void qemuDomainSetFakeReboot(virQEMUDriverPtr driver,
375 376 377
                             virDomainObjPtr vm,
                             bool value);

378
bool qemuDomainJobAllowed(qemuDomainObjPrivatePtr priv,
379
                          qemuDomainJob job);
M
Michal Privoznik 已提交
380

381
int qemuDomainCheckDiskPresence(virQEMUDriverPtr driver,
M
Michal Privoznik 已提交
382 383
                                virDomainObjPtr vm,
                                bool start_with_state);
384

385
int qemuDomainDetermineDiskChain(virQEMUDriverPtr driver,
386
                                 virDomainObjPtr vm,
387
                                 virDomainDiskDefPtr disk,
388 389
                                 bool force_probe,
                                 bool report_broken);
390

391 392 393
int qemuDomainStorageFileInit(virQEMUDriverPtr driver,
                              virDomainObjPtr vm,
                              virStorageSourcePtr src);
394
char *qemuDomainStorageAlias(const char *device, int depth);
395

396 397 398 399
int qemuDomainCleanupAdd(virDomainObjPtr vm,
                         qemuDomainCleanupCallback cb);
void qemuDomainCleanupRemove(virDomainObjPtr vm,
                             qemuDomainCleanupCallback cb);
400
void qemuDomainCleanupRun(virQEMUDriverPtr driver,
401 402
                          virDomainObjPtr vm);

403 404
extern virDomainXMLPrivateDataCallbacks virQEMUDriverPrivateDataCallbacks;
extern virDomainXMLNamespace virQEMUDriverDomainXMLNamespace;
405
extern virDomainDefParserConfig virQEMUDriverDomainDefParserConfig;
406

407
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
408
                               virDomainObjPtr vm, int asyncJob);
409

410 411 412 413
int qemuDomainUpdateMemoryDeviceInfo(virQEMUDriverPtr driver,
                                     virDomainObjPtr vm,
                                     int asyncJob);

414 415 416
bool qemuDomainDefCheckABIStability(virQEMUDriverPtr driver,
                                    virDomainDefPtr src,
                                    virDomainDefPtr dst);
417

418
bool qemuDomainAgentAvailable(virDomainObjPtr vm,
419 420
                              bool reportError);

J
Jiri Denemark 已提交
421 422
int qemuDomainJobInfoUpdateTime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
423 424
int qemuDomainJobInfoUpdateDowntime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
J
Jiri Denemark 已提交
425 426 427 428 429 430 431 432 433 434
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);

435 436
int qemuDomainSupportsBlockJobs(virDomainObjPtr vm, bool *modern)
    ATTRIBUTE_NONNULL(1);
437 438
bool qemuDomainDiskBlockJobIsActive(virDomainDiskDefPtr disk);

439
int qemuDomainAlignMemorySizes(virDomainDefPtr def);
440
void qemuDomainMemoryDeviceAlignSize(virDomainMemoryDefPtr mem);
441

442 443
virDomainChrSourceDefPtr qemuFindAgentConfig(virDomainDefPtr def);

444
#endif /* __QEMU_DOMAIN_H__ */