qemu_conf.h 10.5 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
#ifndef LIBVIRT_QEMU_CONF_H
# define LIBVIRT_QEMU_CONF_H
D
Daniel P. Berrange 已提交
24

M
Michal Privoznik 已提交
25 26
# include <unistd.h>

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

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

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
    const 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 100 101 102
    /* These two directories are ones QEMU processes use (so must match
     * the QEMU user/group */
    char *libDir;
    char *cacheDir;
103
    char *saveDir;
C
Chris Lalancette 已提交
104
    char *snapshotDir;
105
    char *channelTargetDir;
106
    char *nvramDir;
107
    char *swtpmStorageDir;
108

109
    char *defaultTLSx509certdir;
110
    bool defaultTLSx509certdirPresent;
111
    bool defaultTLSx509verify;
112
    char *defaultTLSx509secretUUID;
113

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

    bool spiceTLS;
126
    char *spiceTLSx509certdir;
127 128
    bool spiceSASL;
    char *spiceSASLdir;
129 130
    char *spiceListen;
    char *spicePassword;
131
    bool spiceAutoUnixSocket;
132

133 134 135
    bool chardevTLS;
    char *chardevTLSx509certdir;
    bool chardevTLSx509verify;
136
    bool chardevTLSx509verifyPresent;
137
    char *chardevTLSx509secretUUID;
138

139 140
    char *migrateTLSx509certdir;
    bool migrateTLSx509verify;
141
    bool migrateTLSx509verifyPresent;
142 143
    char *migrateTLSx509secretUUID;

144 145
    unsigned int remotePortMin;
    unsigned int remotePortMax;
146

147 148
    unsigned int webSocketPortMin;
    unsigned int webSocketPortMax;
149

150 151 152
    virHugeTLBFSPtr hugetlbfs;
    size_t nhugetlbfs;

153
    char *bridgeHelperName;
154
    char *prHelperName;
155 156

    bool macFilter;
157

158 159
    bool relaxedACS;
    bool vncAllowHostAudio;
160
    bool nogfxAllowHostAudio;
161 162
    bool clearEmulatorCapabilities;
    bool setProcessName;
163

164 165
    unsigned int maxProcesses;
    unsigned int maxFiles;
166
    unsigned long long maxCore;
167
    bool dumpGuestCore;
168

169
    unsigned int maxQueuedJobs;
170

171
    char **securityDriverNames;
172 173
    bool securityDefaultConfined;
    bool securityRequireConfined;
174 175

    char *saveImageFormat;
176
    char *dumpImageFormat;
177
    char *snapshotImageFormat;
178

H
Hu Tao 已提交
179
    char *autoDumpPath;
180 181
    bool autoDumpBypassCache;
    bool autoStartBypassCache;
H
Hu Tao 已提交
182

183 184 185 186 187 188
    char *lockManagerName;

    int keepAliveInterval;
    unsigned int keepAliveCount;

    int seccompSandbox;
189

190
    char *migrateHost;
191 192
    /* The default for -incoming */
    char *migrationAddress;
193 194
    unsigned int migrationPortMin;
    unsigned int migrationPortMax;
195 196

    bool logTimestamp;
197
    bool stdioLogD;
198

199 200
    virFirmwarePtr *firmwares;
    size_t nfirmwares;
201
    unsigned int glusterDebugLevel;
202 203

    char *memoryBackingDir;
204 205 206

    bool vxhsTLS;
    char *vxhsTLSx509certdir;
207 208 209

    bool nbdTLS;
    char *nbdTLSx509certdir;
210 211 212

    uid_t swtpm_user;
    gid_t swtpm_group;
213 214 215 216 217 218
};

/* Main driver state */
struct _virQEMUDriver {
    virMutex lock;

219 220
    /* Require lock to get reference on 'config',
     * then lockless thereafter */
221 222
    virQEMUDriverConfigPtr config;

223
    /* Immutable pointer, self-locking APIs */
224 225
    virThreadPoolPtr workerPool;

226
    /* Atomic increment only */
E
Erik Skultety 已提交
227
    int lastvmid;
228

229
    /* Atomic inc/dec only */
230
    unsigned int nactive;
231

232 233 234
    /* Immutable value */
    bool privileged;

235
    /* Immutable pointers. Caller must provide locking */
236 237 238
    virStateInhibitCallback inhibitCallback;
    void *inhibitOpaque;

239
    /* Immutable pointer, self-locking APIs */
240
    virDomainObjListPtr domains;
241

242
    /* Immutable pointer */
243 244
    char *qemuImgBinary;

245
    /* Immutable pointer, lockless APIs. Pointless abstraction */
246 247
    ebtablesContext *ebtables;

248 249 250
    /* Require lock to get a reference on the object,
     * lockless access thereafter
     */
251 252
    virCapsPtr caps;

253
    /* Immutable pointer, Immutable object */
254
    virDomainXMLOptionPtr xmlopt;
255

256
    /* Immutable pointer, self-locking APIs */
257
    virFileCachePtr qemuCapsCache;
258

259
    /* Immutable pointer, self-locking APIs */
260
    virObjectEventStatePtr domainEventState;
261

262
    /* Immutable pointer. self-locking APIs */
263 264
    virSecurityManagerPtr securityManager;

265
    virHostdevManagerPtr hostdevMgr;
266

267
    /* Immutable pointer. Unsafe APIs. XXX */
268
    virHashTablePtr sharedDevices;
269

270
    /* Immutable pointer, immutable object */
271
    virPortAllocatorRangePtr remotePorts;
272

273
    /* Immutable pointer, immutable object */
274
    virPortAllocatorRangePtr webSocketPorts;
275

276
    /* Immutable pointer, immutable object */
277
    virPortAllocatorRangePtr migrationPorts;
278

279
    /* Immutable pointer, lockless APIs*/
280
    virSysinfoDefPtr hostsysinfo;
281

282
    /* Immutable pointer. lockless access */
283
    virLockManagerPluginPtr lockManager;
284

285
    /* Immutable pointer, self-clocking APIs */
286
    virCloseCallbacksPtr closeCallbacks;
287 288 289

    /* Immutable pointer, self-locking APIs */
    virHashAtomicPtr migrationErrors;
290 291
};

292 293 294
typedef struct _qemuDomainCmdlineDef qemuDomainCmdlineDef;
typedef qemuDomainCmdlineDef *qemuDomainCmdlineDefPtr;
struct _qemuDomainCmdlineDef {
295
    size_t num_args;
296 297 298 299 300 301 302
    char **args;

    unsigned int num_env;
    char **env_name;
    char **env_value;
};

303 304


305 306
void qemuDomainCmdlineDefFree(qemuDomainCmdlineDefPtr def);

307 308 309
virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged);

int virQEMUDriverConfigLoadFile(virQEMUDriverConfigPtr cfg,
310 311
                                const char *filename,
                                bool privileged);
312

313 314 315
int
virQEMUDriverConfigValidate(virQEMUDriverConfigPtr cfg);

316 317 318
int
virQEMUDriverConfigSetDefaults(virQEMUDriverConfigPtr cfg);

319
virQEMUDriverConfigPtr virQEMUDriverGetConfig(virQEMUDriverPtr driver);
320
bool virQEMUDriverIsPrivileged(virQEMUDriverPtr driver);
321

322 323 324 325
virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver);
virCapsPtr virQEMUDriverGetCapabilities(virQEMUDriverPtr driver,
                                        bool refresh);

326 327
typedef struct _qemuSharedDeviceEntry qemuSharedDeviceEntry;
typedef qemuSharedDeviceEntry *qemuSharedDeviceEntryPtr;
328

329 330
bool qemuSharedDeviceEntryDomainExists(qemuSharedDeviceEntryPtr entry,
                                       const char *name,
331
                                       int *idx)
332 333
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

334
char *qemuGetSharedDeviceKey(const char *disk_path)
335 336
    ATTRIBUTE_NONNULL(1);

J
Ján Tomko 已提交
337
void qemuSharedDeviceEntryFree(void *payload, const void *name);
338

339 340 341 342 343
int qemuAddSharedDisk(virQEMUDriverPtr driver,
                      virDomainDiskDefPtr disk,
                      const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

344 345 346 347 348 349 350 351 352 353
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);

354 355 356 357 358
int qemuRemoveSharedDisk(virQEMUDriverPtr driver,
                         virDomainDiskDefPtr disk,
                         const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

359
int qemuSetUnprivSGIO(virDomainDeviceDefPtr dev);
360

361
int qemuDriverAllocateID(virQEMUDriverPtr driver);
362 363
virDomainXMLOptionPtr virQEMUDriverCreateXMLConf(virQEMUDriverPtr driver);

364
int qemuTranslateSnapshotDiskSourcePool(virDomainSnapshotDiskDefPtr def);
365

366 367 368 369 370 371 372 373
char * qemuGetBaseHugepagePath(virHugeTLBFSPtr hugepage);
char * qemuGetDomainHugepagePath(const virDomainDef *def,
                                 virHugeTLBFSPtr hugepage);

int qemuGetDomainHupageMemPath(const virDomainDef *def,
                               virQEMUDriverConfigPtr cfg,
                               unsigned long long pagesize,
                               char **memPath);
374

375 376 377 378 379 380 381 382
int qemuGetMemoryBackingBasePath(virQEMUDriverConfigPtr cfg,
                                 char **path);
int qemuGetMemoryBackingDomainPath(const virDomainDef *def,
                                   virQEMUDriverConfigPtr cfg,
                                   char **path);
int qemuGetMemoryBackingPath(const virDomainDef *def,
                             virQEMUDriverConfigPtr cfg,
                             const char *alias,
383
                             char **memPath);
384
#endif /* LIBVIRT_QEMU_CONF_H */