qemu_conf.h 11.3 KB
Newer Older
D
Daniel P. Berrange 已提交
1
/*
2
 * qemu_conf.h: QEMU configuration management
D
Daniel P. Berrange 已提交
3
 *
4
 * Copyright (C) 2006-2007, 2009-2013 Red Hat, Inc.
D
Daniel P. Berrange 已提交
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/>.
D
Daniel P. Berrange 已提交
20 21
 */

22 23 24 25 26 27 28 29 30
#pragma once

#include <unistd.h>

#include "virebtables.h"
#include "internal.h"
#include "capabilities.h"
#include "network_conf.h"
#include "domain_conf.h"
31
#include "checkpoint_conf.h"
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
#include "snapshot_conf.h"
#include "domain_event.h"
#include "virthread.h"
#include "security/security_manager.h"
#include "virpci.h"
#include "virusb.h"
#include "virscsi.h"
#include "cpu_conf.h"
#include "driver.h"
#include "virportallocator.h"
#include "vircommand.h"
#include "virthreadpool.h"
#include "locking/lock_manager.h"
#include "qemu_capabilities.h"
#include "virclosecallbacks.h"
#include "virhostdev.h"
#include "virfile.h"
#include "virfilecache.h"
#include "virfirmware.h"

#define QEMU_DRIVER_NAME "QEMU"
C
Chunyan Liu 已提交
53

54 55 56
typedef struct _virQEMUDriver virQEMUDriver;
typedef virQEMUDriver *virQEMUDriverPtr;

57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
typedef struct _virQEMUDriverConfig virQEMUDriverConfig;
typedef virQEMUDriverConfig *virQEMUDriverConfigPtr;

/* Main driver config. The data in these object
 * instances is immutable, so can be accessed
 * without locking. Threads must, however, hold
 * a valid reference on the object to prevent it
 * being released while they use it.
 *
 * eg
 *  qemuDriverLock(driver);
 *  virQEMUDriverConfigPtr cfg = virObjectRef(driver->config);
 *  qemuDriverUnlock(driver);
 *
 *  ...do stuff with 'cfg'..
 *
 *  virObjectUnref(cfg);
 */
struct _virQEMUDriverConfig {
    virObject parent;
H
Hu Tao 已提交
77

78
    char *uri;
79

80 81
    uid_t user;
    gid_t group;
82
    bool dynamicOwnership;
83

84
    virBitmapPtr namespaces;
85
    bool rememberOwner;
86

87 88 89
    int cgroupControllers;
    char **cgroupDeviceACL;

90
    /* These five directories are ones libvirtd uses (so must be root:root
91
     * to avoid security risk from QEMU processes */
92
    char *configBaseDir;
93 94
    char *configDir;
    char *autostartDir;
95
    char *logDir;
96
    char *swtpmLogDir;
97
    char *stateDir;
98
    char *swtpmStateDir;
99
    char *slirpStateDir;
M
Marc-André Lureau 已提交
100
    char *dbusStateDir;
101 102 103 104
    /* These two directories are ones QEMU processes use (so must match
     * the QEMU user/group */
    char *libDir;
    char *cacheDir;
105
    char *saveDir;
C
Chris Lalancette 已提交
106
    char *snapshotDir;
107
    char *checkpointDir;
108
    char *channelTargetDir;
109
    char *nvramDir;
110
    char *swtpmStorageDir;
111

112
    char *defaultTLSx509certdir;
113
    bool defaultTLSx509certdirPresent;
114
    bool defaultTLSx509verify;
115
    char *defaultTLSx509secretUUID;
116

117 118 119
    bool vncAutoUnixSocket;
    bool vncTLS;
    bool vncTLSx509verify;
120
    bool vncTLSx509verifyPresent;
121
    bool vncSASL;
D
Daniel P. Berrange 已提交
122
    char *vncTLSx509certdir;
123
    char *vncTLSx509secretUUID;
124
    char *vncListen;
125
    char *vncPassword;
126
    char *vncSASLdir;
127 128

    bool spiceTLS;
129
    char *spiceTLSx509certdir;
130 131
    bool spiceSASL;
    char *spiceSASLdir;
132 133
    char *spiceListen;
    char *spicePassword;
134
    bool spiceAutoUnixSocket;
135

136 137 138
    bool chardevTLS;
    char *chardevTLSx509certdir;
    bool chardevTLSx509verify;
139
    bool chardevTLSx509verifyPresent;
140
    char *chardevTLSx509secretUUID;
141

142 143
    char *migrateTLSx509certdir;
    bool migrateTLSx509verify;
144
    bool migrateTLSx509verifyPresent;
145 146
    char *migrateTLSx509secretUUID;

147 148
    unsigned int remotePortMin;
    unsigned int remotePortMax;
149

150 151
    unsigned int webSocketPortMin;
    unsigned int webSocketPortMax;
152

153 154 155
    virHugeTLBFSPtr hugetlbfs;
    size_t nhugetlbfs;

156
    char *bridgeHelperName;
157
    char *prHelperName;
158
    char *slirpHelperName;
159
    char *dbusDaemonName;
160 161

    bool macFilter;
162

163 164
    bool relaxedACS;
    bool vncAllowHostAudio;
165
    bool nogfxAllowHostAudio;
166
    bool setProcessName;
167

168 169
    unsigned int maxProcesses;
    unsigned int maxFiles;
170
    unsigned int maxThreadsPerProc;
171
    unsigned long long maxCore;
172
    bool dumpGuestCore;
173

174
    unsigned int maxQueuedJobs;
175

176
    char **securityDriverNames;
177 178
    bool securityDefaultConfined;
    bool securityRequireConfined;
179 180

    char *saveImageFormat;
181
    char *dumpImageFormat;
182
    char *snapshotImageFormat;
183

H
Hu Tao 已提交
184
    char *autoDumpPath;
185 186
    bool autoDumpBypassCache;
    bool autoStartBypassCache;
H
Hu Tao 已提交
187

188 189 190 191 192 193
    char *lockManagerName;

    int keepAliveInterval;
    unsigned int keepAliveCount;

    int seccompSandbox;
194

195
    char *migrateHost;
196 197
    /* The default for -incoming */
    char *migrationAddress;
198 199
    unsigned int migrationPortMin;
    unsigned int migrationPortMax;
200 201

    bool logTimestamp;
202
    bool stdioLogD;
203

204 205
    virFirmwarePtr *firmwares;
    size_t nfirmwares;
206
    unsigned int glusterDebugLevel;
207
    bool virtiofsdDebug;
208 209

    char *memoryBackingDir;
210 211 212

    bool vxhsTLS;
    char *vxhsTLSx509certdir;
213 214 215

    bool nbdTLS;
    char *nbdTLSx509certdir;
216 217 218

    uid_t swtpm_user;
    gid_t swtpm_group;
219 220

    char **capabilityfilters;
221 222
};

223 224 225
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virQEMUDriverConfig, virObjectUnref);


226 227 228 229
/* Main driver state */
struct _virQEMUDriver {
    virMutex lock;

230 231
    /* Require lock to get reference on 'config',
     * then lockless thereafter */
232 233
    virQEMUDriverConfigPtr config;

234 235 236
    /* pid file FD, ensures two copies of the driver can't use the same root */
    int lockFD;

237
    /* Immutable pointer, self-locking APIs */
238 239
    virThreadPoolPtr workerPool;

240
    /* Atomic increment only */
E
Erik Skultety 已提交
241
    int lastvmid;
242

243
    /* Atomic inc/dec only */
244
    unsigned int nactive;
245

246
    /* Immutable values */
247
    bool privileged;
248
    char *embeddedRoot;
249

250
    /* Immutable pointers. Caller must provide locking */
251 252 253
    virStateInhibitCallback inhibitCallback;
    void *inhibitOpaque;

254
    /* Immutable pointer, self-locking APIs */
255
    virDomainObjListPtr domains;
256

257
    /* Immutable pointer */
258 259
    char *qemuImgBinary;

260
    /* Immutable pointer, lockless APIs. Pointless abstraction */
261 262
    ebtablesContext *ebtables;

263 264 265
    /* Require lock to get a reference on the object,
     * lockless access thereafter
     */
266 267
    virCapsPtr caps;

268 269 270 271 272
    /* Lazy initialized on first use, immutable thereafter.
     * Require lock to get the pointer & do optional initialization
     */
    virCapsHostNUMAPtr hostnuma;

273 274 275 276 277
    /* Lazy initialized on first use, immutable thereafter.
     * Require lock to get the pointer & do optional initialization
     */
    virCPUDefPtr hostcpu;

278 279 280
    /* Immutable value */
    virArch hostarch;

281
    /* Immutable pointer, Immutable object */
282
    virDomainXMLOptionPtr xmlopt;
283

284
    /* Immutable pointer, self-locking APIs */
285
    virFileCachePtr qemuCapsCache;
286

287
    /* Immutable pointer, self-locking APIs */
288
    virObjectEventStatePtr domainEventState;
289

290
    /* Immutable pointer. self-locking APIs */
291 292
    virSecurityManagerPtr securityManager;

293
    virHostdevManagerPtr hostdevMgr;
294

295
    /* Immutable pointer. Unsafe APIs. XXX */
296
    virHashTablePtr sharedDevices;
297

298
    /* Immutable pointer, immutable object */
299
    virPortAllocatorRangePtr remotePorts;
300

301
    /* Immutable pointer, immutable object */
302
    virPortAllocatorRangePtr webSocketPorts;
303

304
    /* Immutable pointer, immutable object */
305
    virPortAllocatorRangePtr migrationPorts;
306

J
Ján Tomko 已提交
307
    /* Immutable pointer, lockless APIs */
308
    virSysinfoDefPtr hostsysinfo;
309

310
    /* Immutable pointer. lockless access */
311
    virLockManagerPluginPtr lockManager;
312

313
    /* Immutable pointer, self-clocking APIs */
314
    virCloseCallbacksPtr closeCallbacks;
315 316 317

    /* Immutable pointer, self-locking APIs */
    virHashAtomicPtr migrationErrors;
318 319
};

320 321
virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged,
                                              const char *root);
322 323

int virQEMUDriverConfigLoadFile(virQEMUDriverConfigPtr cfg,
324 325
                                const char *filename,
                                bool privileged);
326

327 328 329
int
virQEMUDriverConfigValidate(virQEMUDriverConfigPtr cfg);

330 331 332
int
virQEMUDriverConfigSetDefaults(virQEMUDriverConfigPtr cfg);

333
virQEMUDriverConfigPtr virQEMUDriverGetConfig(virQEMUDriverPtr driver);
334

335
virCapsHostNUMAPtr virQEMUDriverGetHostNUMACaps(virQEMUDriverPtr driver);
336
virCPUDefPtr virQEMUDriverGetHostCPU(virQEMUDriverPtr driver);
337 338 339 340
virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver);
virCapsPtr virQEMUDriverGetCapabilities(virQEMUDriverPtr driver,
                                        bool refresh);

341 342 343 344 345 346 347
virDomainCapsPtr
virQEMUDriverGetDomainCapabilities(virQEMUDriverPtr driver,
                                   virQEMUCapsPtr qemuCaps,
                                   const char *machine,
                                   virArch arch,
                                   virDomainVirtType virttype);

348 349
typedef struct _qemuSharedDeviceEntry qemuSharedDeviceEntry;
typedef qemuSharedDeviceEntry *qemuSharedDeviceEntryPtr;
350

351 352
bool qemuSharedDeviceEntryDomainExists(qemuSharedDeviceEntryPtr entry,
                                       const char *name,
353
                                       int *idx)
354 355
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

356
char *qemuGetSharedDeviceKey(const char *disk_path)
357 358
    ATTRIBUTE_NONNULL(1);

359
void qemuSharedDeviceEntryFree(void *payload);
360

361 362 363 364 365
int qemuAddSharedDisk(virQEMUDriverPtr driver,
                      virDomainDiskDefPtr disk,
                      const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

366 367 368 369 370 371 372 373 374 375
int qemuAddSharedDevice(virQEMUDriverPtr driver,
                        virDomainDeviceDefPtr dev,
                        const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

int qemuRemoveSharedDevice(virQEMUDriverPtr driver,
                           virDomainDeviceDefPtr dev,
                           const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

376 377 378 379 380
int qemuRemoveSharedDisk(virQEMUDriverPtr driver,
                         virDomainDiskDefPtr disk,
                         const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

381
int qemuSetUnprivSGIO(virDomainDeviceDefPtr dev);
382

383
int qemuDriverAllocateID(virQEMUDriverPtr driver);
384 385
virDomainXMLOptionPtr virQEMUDriverCreateXMLConf(virQEMUDriverPtr driver,
                                                 const char *defsecmodel);
386

387
int qemuTranslateSnapshotDiskSourcePool(virDomainSnapshotDiskDefPtr def);
388

389 390 391 392
char * qemuGetBaseHugepagePath(virQEMUDriverPtr driver,
                               virHugeTLBFSPtr hugepage);
char * qemuGetDomainHugepagePath(virQEMUDriverPtr driver,
                                 const virDomainDef *def,
393 394
                                 virHugeTLBFSPtr hugepage);

395 396
int qemuGetDomainHupageMemPath(virQEMUDriverPtr driver,
                               const virDomainDef *def,
397 398
                               unsigned long long pagesize,
                               char **memPath);
399

400 401
int qemuGetMemoryBackingDomainPath(virQEMUDriverPtr driver,
                                   const virDomainDef *def,
402
                                   char **path);
403 404
int qemuGetMemoryBackingPath(virQEMUDriverPtr driver,
                             const virDomainDef *def,
405
                             const char *alias,
406
                             char **memPath);