qemu_conf.h 10.1 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 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
#pragma once

#include <unistd.h>

#include "virebtables.h"
#include "internal.h"
#include "capabilities.h"
#include "network_conf.h"
#include "domain_conf.h"
#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 已提交
52

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

56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
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 已提交
76

77
    const char *uri;
78

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

83
    virBitmapPtr namespaces;
84
    bool rememberOwner;
85

86 87 88
    int cgroupControllers;
    char **cgroupDeviceACL;

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

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

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

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

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

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

143 144
    unsigned int remotePortMin;
    unsigned int remotePortMax;
145

146 147
    unsigned int webSocketPortMin;
    unsigned int webSocketPortMax;
148

149 150 151
    virHugeTLBFSPtr hugetlbfs;
    size_t nhugetlbfs;

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

    bool macFilter;
156

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

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

168
    unsigned int maxQueuedJobs;
169

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

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

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

182 183 184 185 186 187
    char *lockManagerName;

    int keepAliveInterval;
    unsigned int keepAliveCount;

    int seccompSandbox;
188

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

    bool logTimestamp;
196
    bool stdioLogD;
197

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

    char *memoryBackingDir;
203 204 205

    bool vxhsTLS;
    char *vxhsTLSx509certdir;
206 207 208

    bool nbdTLS;
    char *nbdTLSx509certdir;
209 210 211

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

264
    virHostdevManagerPtr hostdevMgr;
265

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

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

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

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

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

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

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

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

291 292 293
virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged);

int virQEMUDriverConfigLoadFile(virQEMUDriverConfigPtr cfg,
294 295
                                const char *filename,
                                bool privileged);
296

297 298 299
int
virQEMUDriverConfigValidate(virQEMUDriverConfigPtr cfg);

300 301 302
int
virQEMUDriverConfigSetDefaults(virQEMUDriverConfigPtr cfg);

303
virQEMUDriverConfigPtr virQEMUDriverGetConfig(virQEMUDriverPtr driver);
304
bool virQEMUDriverIsPrivileged(virQEMUDriverPtr driver);
305

306 307 308 309
virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver);
virCapsPtr virQEMUDriverGetCapabilities(virQEMUDriverPtr driver,
                                        bool refresh);

310 311
typedef struct _qemuSharedDeviceEntry qemuSharedDeviceEntry;
typedef qemuSharedDeviceEntry *qemuSharedDeviceEntryPtr;
312

313 314
bool qemuSharedDeviceEntryDomainExists(qemuSharedDeviceEntryPtr entry,
                                       const char *name,
315
                                       int *idx)
316 317
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

318
char *qemuGetSharedDeviceKey(const char *disk_path)
319 320
    ATTRIBUTE_NONNULL(1);

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

323 324 325 326 327
int qemuAddSharedDisk(virQEMUDriverPtr driver,
                      virDomainDiskDefPtr disk,
                      const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

328 329 330 331 332 333 334 335 336 337
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);

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

343
int qemuSetUnprivSGIO(virDomainDeviceDefPtr dev);
344

345
int qemuDriverAllocateID(virQEMUDriverPtr driver);
346 347
virDomainXMLOptionPtr virQEMUDriverCreateXMLConf(virQEMUDriverPtr driver);

348
int qemuTranslateSnapshotDiskSourcePool(virDomainSnapshotDiskDefPtr def);
349

350 351 352 353 354 355 356 357
char * qemuGetBaseHugepagePath(virHugeTLBFSPtr hugepage);
char * qemuGetDomainHugepagePath(const virDomainDef *def,
                                 virHugeTLBFSPtr hugepage);

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

359 360 361 362 363 364 365 366
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,
367
                             char **memPath);