qemu_conf.h 8.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
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

24
#ifndef __QEMUD_CONF_H
25
# define __QEMUD_CONF_H
D
Daniel P. Berrange 已提交
26

27
# include <config.h>
28

29
# include "virebtables.h"
30 31 32 33 34
# include "internal.h"
# include "capabilities.h"
# include "network_conf.h"
# include "domain_conf.h"
# include "domain_event.h"
35
# include "virthread.h"
36
# include "security/security_manager.h"
37
# include "vircgroup.h"
38
# include "virpci.h"
39
# include "virusb.h"
40 41
# include "cpu_conf.h"
# include "driver.h"
42
# include "virportallocator.h"
43
# include "vircommand.h"
44
# include "virthreadpool.h"
45
# include "locking/lock_manager.h"
46
# include "qemu_capabilities.h"
47

48
# define QEMUD_CPUMASK_LEN CPU_SETSIZE
49

50 51
typedef struct _virQEMUCloseCallbacks virQEMUCloseCallbacks;
typedef virQEMUCloseCallbacks *virQEMUCloseCallbacksPtr;
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
    bool privileged;
78
    const char *uri;
79

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

84 85 86
    int cgroupControllers;
    char **cgroupDeviceACL;

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

    bool vncAutoUnixSocket;
    bool vncTLS;
    bool vncTLSx509verify;
    bool vncSASL;
D
Daniel P. Berrange 已提交
105
    char *vncTLSx509certdir;
106
    char *vncListen;
107
    char *vncPassword;
108
    char *vncSASLdir;
109 110

    bool spiceTLS;
111 112 113
    char *spiceTLSx509certdir;
    char *spiceListen;
    char *spicePassword;
114

115 116
    int remotePortMin;
    int remotePortMax;
117

118 119 120 121
    char *hugetlbfsMount;
    char *hugepagePath;

    bool macFilter;
122

123 124 125 126 127
    bool relaxedACS;
    bool vncAllowHostAudio;
    bool clearEmulatorCapabilities;
    bool allowDiskFormatProbing;
    bool setProcessName;
128

129
    int maxProcesses;
130
    int maxFiles;
131

132
    int maxQueuedJobs;
133

134
    char **securityDriverNames;
135 136
    bool securityDefaultConfined;
    bool securityRequireConfined;
137 138

    char *saveImageFormat;
139
    char *dumpImageFormat;
140

H
Hu Tao 已提交
141
    char *autoDumpPath;
142 143
    bool autoDumpBypassCache;
    bool autoStartBypassCache;
H
Hu Tao 已提交
144

145 146 147 148 149 150 151 152 153 154 155 156
    char *lockManagerName;

    int keepAliveInterval;
    unsigned int keepAliveCount;

    int seccompSandbox;
};

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

157 158
    /* Require lock to get reference on 'config',
     * then lockless thereafter */
159 160
    virQEMUDriverConfigPtr config;

161
    /* Immutable pointer, self-locking APIs */
162 163
    virThreadPoolPtr workerPool;

164
    /* Atomic increment only */
165 166
    int nextvmid;

167
    /* Immutable pointer. Immutable object */
168 169
    virCgroupPtr cgroup;

170
    /* Atomic inc/dec only */
171
    unsigned int nactive;
172

173
    /* Immutable pointers. Caller must provide locking */
174 175 176
    virStateInhibitCallback inhibitCallback;
    void *inhibitOpaque;

177
    /* Immutable pointer, self-locking APIs */
178
    virDomainObjListPtr domains;
179

180
    /* Immutable pointer */
181 182
    char *qemuImgBinary;

183
    /* Immutable pointer, lockless APIs. Pointless abstraction */
184 185
    ebtablesContext *ebtables;

186 187 188
    /* Require lock to get a reference on the object,
     * lockless access thereafter
     */
189 190
    virCapsPtr caps;

191
    /* Immutable pointer, self-locking APIs */
192
    virQEMUCapsCachePtr qemuCapsCache;
193

194
    /* Immutable pointer, self-locking APIs */
195 196
    virDomainEventStatePtr domainEventState;

197
    /* Immutable pointer. self-locking APIs */
198 199
    virSecurityManagerPtr securityManager;

200 201 202
    /* Immutable pointers. Requires locks to be held before
     * calling APIs. activePciHostdevs must be locked before
     * inactivePciHostdevs */
203 204
    virPCIDeviceListPtr activePciHostdevs;
    virPCIDeviceListPtr inactivePciHostdevs;
205
    virUSBDeviceListPtr activeUsbHostdevs;
206

207
    /* Immutable pointer. Unsafe APIs. XXX */
208 209
    virHashTablePtr sharedDisks;

210
    /* Immutable pointer, self-locking APIs */
211
    virPortAllocatorPtr remotePorts;
212

213
    /* Immutable pointer, lockless APIs*/
214
    virSysinfoDefPtr hostsysinfo;
215

216
    /* Immutable pointer. lockless access */
217
    virLockManagerPluginPtr lockManager;
218

219 220
    /* Immutable pointer, self-clocking APIs */
    virQEMUCloseCallbacksPtr closeCallbacks;
221 222
};

223 224 225 226 227 228 229 230 231 232 233
typedef struct _qemuDomainCmdlineDef qemuDomainCmdlineDef;
typedef qemuDomainCmdlineDef *qemuDomainCmdlineDefPtr;
struct _qemuDomainCmdlineDef {
    unsigned int num_args;
    char **args;

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

D
Daniel Veillard 已提交
234
/* Port numbers used for KVM migration. */
235 236
# define QEMUD_MIGRATION_FIRST_PORT 49152
# define QEMUD_MIGRATION_NUM_PORTS 64
237 238


239 240 241 242 243 244
virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged);

int virQEMUDriverConfigLoadFile(virQEMUDriverConfigPtr cfg,
                                const char *filename);

virQEMUDriverConfigPtr virQEMUDriverGetConfig(virQEMUDriverPtr driver);
245

246 247 248 249
virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver);
virCapsPtr virQEMUDriverGetCapabilities(virQEMUDriverPtr driver,
                                        bool refresh);

250 251 252 253
struct qemuDomainDiskInfo {
    bool removable;
    bool locked;
    bool tray_open;
254
    int io_status;
255 256
};

257 258 259 260 261 262 263 264 265
typedef virDomainObjPtr (*virQEMUCloseCallback)(virQEMUDriverPtr driver,
                                                virDomainObjPtr vm,
                                                virConnectPtr conn);
virQEMUCloseCallbacksPtr virQEMUCloseCallbacksNew(void);
int virQEMUCloseCallbacksSet(virQEMUCloseCallbacksPtr closeCallbacks,
                             virDomainObjPtr vm,
                             virConnectPtr conn,
                             virQEMUCloseCallback cb);
int virQEMUCloseCallbacksUnset(virQEMUCloseCallbacksPtr closeCallbacks,
266
                               virDomainObjPtr vm,
267 268 269 270 271 272 273 274
                               virQEMUCloseCallback cb);
virQEMUCloseCallback
virQEMUCloseCallbacksGet(virQEMUCloseCallbacksPtr closeCallbacks,
                         virDomainObjPtr vm,
                         virConnectPtr conn);
void virQEMUCloseCallbacksRun(virQEMUCloseCallbacksPtr closeCallbacks,
                              virConnectPtr conn,
                              virQEMUDriverPtr driver);
275

276 277 278 279 280 281
typedef struct _qemuSharedDiskEntry qemuSharedDiskEntry;
typedef qemuSharedDiskEntry *qemuSharedDiskEntryPtr;

bool qemuSharedDiskEntryDomainExists(qemuSharedDiskEntryPtr entry,
                                     const char *name,
                                     int *index)
282 283
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

284 285 286 287 288
int qemuAddSharedDisk(virQEMUDriverPtr driver,
                      virDomainDiskDefPtr disk,
                      const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

289
int qemuRemoveSharedDisk(virQEMUDriverPtr driver,
290 291 292 293
                         virDomainDiskDefPtr disk,
                         const char *name)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

294 295 296
char * qemuGetSharedDiskKey(const char *disk_path)
    ATTRIBUTE_NONNULL(1);

297 298 299
void qemuSharedDiskEntryFree(void *payload, const void *name)
    ATTRIBUTE_NONNULL(1);

300 301
int qemuDriverAllocateID(virQEMUDriverPtr driver);

302
#endif /* __QEMUD_CONF_H */