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

M
Matthias Bolte 已提交
38 39 40 41 42 43
# define QEMU_EXPECTED_VIRT_TYPES      \
    ((1 << VIR_DOMAIN_VIRT_QEMU) |     \
     (1 << VIR_DOMAIN_VIRT_KQEMU) |    \
     (1 << VIR_DOMAIN_VIRT_KVM) |      \
     (1 << VIR_DOMAIN_VIRT_XEN))

44 45 46 47
# define QEMU_DOMAIN_FORMAT_LIVE_FLAGS      \
    (VIR_DOMAIN_XML_SECURE |                \
     VIR_DOMAIN_XML_UPDATE_CPU)

48 49 50
# 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.  */
51
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX ULONG_MAX
52
# else
53
#  define QEMU_DOMAIN_MIG_BANDWIDTH_MAX (INT64_MAX / (1024 * 1024))
54
# endif
55

56
# define JOB_MASK(job)                  (1 << (job - 1))
57
# define QEMU_JOB_DEFAULT_MASK          \
58 59 60
    (JOB_MASK(QEMU_JOB_QUERY) |         \
     JOB_MASK(QEMU_JOB_DESTROY) |       \
     JOB_MASK(QEMU_JOB_ABORT))
61

62 63 64 65 66
/* 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))

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

79
    /* The following two items must always be the last items before JOB_LAST */
80 81
    QEMU_JOB_ASYNC,         /* Asynchronous job */
    QEMU_JOB_ASYNC_NESTED,  /* Normal job within an async job */
82 83

    QEMU_JOB_LAST
84
} qemuDomainJob;
85
VIR_ENUM_DECL(qemuDomainJob)
86 87 88 89 90

/* 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.
 */
91
typedef enum {
92 93 94 95 96
    QEMU_ASYNC_JOB_NONE = 0,
    QEMU_ASYNC_JOB_MIGRATION_OUT,
    QEMU_ASYNC_JOB_MIGRATION_IN,
    QEMU_ASYNC_JOB_SAVE,
    QEMU_ASYNC_JOB_DUMP,
97
    QEMU_ASYNC_JOB_SNAPSHOT,
98 99

    QEMU_ASYNC_JOB_LAST
100
} qemuDomainAsyncJob;
101
VIR_ENUM_DECL(qemuDomainAsyncJob)
102

J
Jiri Denemark 已提交
103 104 105 106 107
typedef struct _qemuDomainJobInfo qemuDomainJobInfo;
typedef qemuDomainJobInfo *qemuDomainJobInfoPtr;
struct _qemuDomainJobInfo {
    virDomainJobType type;
    unsigned long long started; /* When the async job started */
108
    unsigned long long stopped; /* When the domain's CPUs were stopped */
J
Jiri Denemark 已提交
109 110 111 112 113 114 115
    /* Computed values */
    unsigned long long timeElapsed;
    unsigned long long timeRemaining;
    /* Raw values from QEMU */
    qemuMonitorMigrationStatus status;
};

116
struct qemuDomainJobObj {
117
    virCond cond;                       /* Use to coordinate jobs */
118
    qemuDomainJob active;               /* Currently running job */
119
    unsigned long long owner;           /* Thread id which set current job */
120

121
    virCond asyncCond;                  /* Use to coordinate with async jobs */
122
    qemuDomainAsyncJob asyncJob;        /* Currently active async job */
123
    unsigned long long asyncOwner;      /* Thread which set current async job */
J
Jiri Denemark 已提交
124
    int phase;                          /* Job phase (mainly for migrations) */
125
    unsigned long long mask;            /* Jobs allowed during async job */
126
    bool dump_memory_only;              /* use dump-guest-memory to do dump */
J
Jiri Denemark 已提交
127
    qemuDomainJobInfoPtr current;       /* async job progress data */
128
    qemuDomainJobInfoPtr completed;     /* statistics data of a recently completed job */
129
    bool asyncAbort;                    /* abort of async job requested */
130 131
};

132
typedef void (*qemuDomainCleanupCallback)(virQEMUDriverPtr driver,
133 134
                                          virDomainObjPtr vm);

135 136 137
typedef struct _qemuDomainObjPrivate qemuDomainObjPrivate;
typedef qemuDomainObjPrivate *qemuDomainObjPrivatePtr;
struct _qemuDomainObjPrivate {
138
    struct qemuDomainJobObj job;
139 140

    qemuMonitorPtr mon;
141
    virDomainChrSourceDefPtr monConfig;
E
Eric Blake 已提交
142
    bool monJSON;
143 144
    bool monError;
    unsigned long long monStart;
D
Daniel P. Berrange 已提交
145 146 147 148 149

    qemuAgentPtr agent;
    bool agentError;
    unsigned long long agentStart;

150
    bool gotShutdown;
151
    bool beingDestroyed;
152
    char *pidfile;
153 154 155 156

    int nvcpupids;
    int *vcpupids;

157
    virDomainPCIAddressSetPtr pciaddrs;
J
Ján Tomko 已提交
158
    virDomainCCWAddressSetPtr ccwaddrs;
159
    int persistentAddrs;
160

161
    virQEMUCapsPtr qemuCaps;
162
    char *lockState;
163 164

    bool fakeReboot;
165 166

    int jobs_queued;
167 168

    unsigned long migMaxBandwidth;
J
Jiri Denemark 已提交
169
    char *origname;
170
    int nbdPort; /* Port used for migration with NBD */
171
    unsigned short migrationPort;
172
    int preMigrationState;
173

174
    virChrdevsPtr devs;
175 176 177 178

    qemuDomainCleanupCallback *cleanupCallbacks;
    size_t ncleanupCallbacks;
    size_t ncleanupCallbacks_max;
179 180

    virCgroupPtr cgroup;
181 182 183

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

    bool hookRun;  /* true if there was a hook run over this domain */
187 188

    bool quiesced; /* true if filesystems are quiesced */
189 190
};

C
Chen Fan 已提交
191 192
typedef enum {
    QEMU_PROCESS_EVENT_WATCHDOG = 0,
193
    QEMU_PROCESS_EVENT_GUESTPANIC,
194
    QEMU_PROCESS_EVENT_DEVICE_DELETED,
C
Chen Fan 已提交
195 196 197 198 199

    QEMU_PROCESS_EVENT_LAST
} qemuProcessEventType;

struct qemuProcessEvent {
200
    virDomainObjPtr vm;
C
Chen Fan 已提交
201
    qemuProcessEventType eventType;
202
    int action;
203
    void *data;
204 205
};

206
const char *qemuDomainAsyncJobPhaseToString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
207
                                            int phase);
208
int qemuDomainAsyncJobPhaseFromString(qemuDomainAsyncJob job,
J
Jiri Denemark 已提交
209 210
                                      const char *phase);

211
void qemuDomainEventFlush(int timer, void *opaque);
212

213
void qemuDomainEventQueue(virQEMUDriverPtr driver,
214
                          virObjectEventPtr event);
215

216
int qemuDomainObjBeginJob(virQEMUDriverPtr driver,
217
                          virDomainObjPtr obj,
218
                          qemuDomainJob job)
219
    ATTRIBUTE_RETURN_CHECK;
220
int qemuDomainObjBeginAsyncJob(virQEMUDriverPtr driver,
221
                               virDomainObjPtr obj,
222
                               qemuDomainAsyncJob asyncJob)
223 224
    ATTRIBUTE_RETURN_CHECK;

225
bool qemuDomainObjEndJob(virQEMUDriverPtr driver,
226
                         virDomainObjPtr obj)
227
    ATTRIBUTE_RETURN_CHECK;
228
bool qemuDomainObjEndAsyncJob(virQEMUDriverPtr driver,
229
                              virDomainObjPtr obj)
230
    ATTRIBUTE_RETURN_CHECK;
231
void qemuDomainObjAbortAsyncJob(virDomainObjPtr obj);
232
void qemuDomainObjSetJobPhase(virQEMUDriverPtr driver,
J
Jiri Denemark 已提交
233 234
                              virDomainObjPtr obj,
                              int phase);
235 236
void qemuDomainObjSetAsyncJobMask(virDomainObjPtr obj,
                                  unsigned long long allowedJobs);
237 238
void qemuDomainObjRestoreJob(virDomainObjPtr obj,
                             struct qemuDomainJobObj *job);
239
void qemuDomainObjTransferJob(virDomainObjPtr obj);
240
void qemuDomainObjDiscardAsyncJob(virQEMUDriverPtr driver,
241
                                  virDomainObjPtr obj);
242
void qemuDomainObjReleaseAsyncJob(virDomainObjPtr obj);
243

244
void qemuDomainObjEnterMonitor(virQEMUDriverPtr driver,
245 246
                               virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
247
void qemuDomainObjExitMonitor(virQEMUDriverPtr driver,
248 249
                              virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
250
int qemuDomainObjEnterMonitorAsync(virQEMUDriverPtr driver,
251
                                   virDomainObjPtr obj,
252
                                   qemuDomainAsyncJob asyncJob)
253
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
254 255


256 257 258 259
void qemuDomainObjEnterAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitAgent(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
D
Daniel P. Berrange 已提交
260 261


262 263 264 265
void qemuDomainObjEnterRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
void qemuDomainObjExitRemote(virDomainObjPtr obj)
    ATTRIBUTE_NONNULL(1);
266

267 268 269 270
virDomainDefPtr qemuDomainDefCopy(virQEMUDriverPtr driver,
                                  virDomainDefPtr src,
                                  unsigned int flags);

271
int qemuDomainDefFormatBuf(virQEMUDriverPtr driver,
272 273 274 275
                           virDomainDefPtr vm,
                           unsigned int flags,
                           virBuffer *buf);

276
char *qemuDomainDefFormatXML(virQEMUDriverPtr driver,
277
                             virDomainDefPtr vm,
278
                             unsigned int flags);
279

280
char *qemuDomainFormatXML(virQEMUDriverPtr driver,
281
                          virDomainObjPtr vm,
282
                          unsigned int flags);
283

284
char *qemuDomainDefFormatLive(virQEMUDriverPtr driver,
285
                              virDomainDefPtr def,
286 287
                              bool inactive,
                              bool compatible);
288

289
void qemuDomainObjTaint(virQEMUDriverPtr driver,
290
                        virDomainObjPtr obj,
291
                        virDomainTaintFlags taint,
292
                        int logFD);
293

294
void qemuDomainObjCheckTaint(virQEMUDriverPtr driver,
295 296
                             virDomainObjPtr obj,
                             int logFD);
297
void qemuDomainObjCheckDiskTaint(virQEMUDriverPtr driver,
298
                                 virDomainObjPtr obj,
299 300
                                 virDomainDiskDefPtr disk,
                                 int logFD);
301
void qemuDomainObjCheckNetTaint(virQEMUDriverPtr driver,
302
                                virDomainObjPtr obj,
303 304
                                virDomainNetDefPtr net,
                                int logFD);
305

306

307 308 309
int qemuDomainCreateLog(virQEMUDriverPtr driver, virDomainObjPtr vm, bool append);
int qemuDomainOpenLog(virQEMUDriverPtr driver, virDomainObjPtr vm, off_t pos);
int qemuDomainAppendLog(virQEMUDriverPtr driver,
310 311 312
                        virDomainObjPtr vm,
                        int logFD,
                        const char *fmt, ...) ATTRIBUTE_FMT_PRINTF(4, 5);
313

314
const char *qemuFindQemuImgBinary(virQEMUDriverPtr driver);
315 316 317 318 319

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

320
int qemuDomainSnapshotForEachQcow2(virQEMUDriverPtr driver,
321 322 323 324 325
                                   virDomainObjPtr vm,
                                   virDomainSnapshotObjPtr snap,
                                   const char *op,
                                   bool try_all);

326
int qemuDomainSnapshotDiscard(virQEMUDriverPtr driver,
327 328 329 330 331
                              virDomainObjPtr vm,
                              virDomainSnapshotObjPtr snap,
                              bool update_current,
                              bool metadata_only);

332 333 334
typedef struct _virQEMUSnapRemove virQEMUSnapRemove;
typedef virQEMUSnapRemove *virQEMUSnapRemovePtr;
struct _virQEMUSnapRemove {
335
    virQEMUDriverPtr driver;
336 337 338 339 340 341 342 343 344 345
    virDomainObjPtr vm;
    int err;
    bool metadata_only;
    bool current;
};

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

346
int qemuDomainSnapshotDiscardAllMetadata(virQEMUDriverPtr driver,
347 348
                                         virDomainObjPtr vm);

349
void qemuDomainRemoveInactive(virQEMUDriverPtr driver,
350 351
                              virDomainObjPtr vm);

352
void qemuDomainSetFakeReboot(virQEMUDriverPtr driver,
353 354 355
                             virDomainObjPtr vm,
                             bool value);

356
bool qemuDomainJobAllowed(qemuDomainObjPrivatePtr priv,
357
                          qemuDomainJob job);
M
Michal Privoznik 已提交
358

359
int qemuDomainCheckDiskPresence(virQEMUDriverPtr driver,
M
Michal Privoznik 已提交
360 361
                                virDomainObjPtr vm,
                                bool start_with_state);
362

363
int qemuDomainDetermineDiskChain(virQEMUDriverPtr driver,
364
                                 virDomainObjPtr vm,
365 366
                                 virDomainDiskDefPtr disk,
                                 bool force);
367

368 369 370 371
int qemuDomainStorageFileInit(virQEMUDriverPtr driver,
                              virDomainObjPtr vm,
                              virStorageSourcePtr src);

372 373 374 375
int qemuDomainCleanupAdd(virDomainObjPtr vm,
                         qemuDomainCleanupCallback cb);
void qemuDomainCleanupRemove(virDomainObjPtr vm,
                             qemuDomainCleanupCallback cb);
376
void qemuDomainCleanupRun(virQEMUDriverPtr driver,
377 378
                          virDomainObjPtr vm);

379 380
extern virDomainXMLPrivateDataCallbacks virQEMUDriverPrivateDataCallbacks;
extern virDomainXMLNamespace virQEMUDriverDomainXMLNamespace;
381
extern virDomainDefParserConfig virQEMUDriverDomainDefParserConfig;
382

383
int qemuDomainUpdateDeviceList(virQEMUDriverPtr driver,
384
                               virDomainObjPtr vm, int asyncJob);
385

386 387 388
bool qemuDomainDefCheckABIStability(virQEMUDriverPtr driver,
                                    virDomainDefPtr src,
                                    virDomainDefPtr dst);
389 390 391 392

bool qemuDomainAgentAvailable(qemuDomainObjPrivatePtr priv,
                              bool reportError);

J
Jiri Denemark 已提交
393 394
int qemuDomainJobInfoUpdateTime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
395 396
int qemuDomainJobInfoUpdateDowntime(qemuDomainJobInfoPtr jobInfo)
    ATTRIBUTE_NONNULL(1);
J
Jiri Denemark 已提交
397 398 399 400 401 402 403 404 405 406
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);

407
#endif /* __QEMU_DOMAIN_H__ */