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

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

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

E
Eric Blake 已提交
47 48 49 50 51 52 53
# ifdef CPU_SETSIZE /* Linux */
#  define QEMUD_CPUMASK_LEN CPU_SETSIZE
# elif defined(_SC_NPROCESSORS_CONF) /* Cygwin */
#  define QEMUD_CPUMASK_LEN (sysconf(_SC_NPROCESSORS_CONF))
# else
#  error "Port me"
# endif
54

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

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

79
    bool privileged;
80
    const char *uri;
81

82 83
    uid_t user;
    gid_t group;
84
    int dynamicOwnership;
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 *stateDir;
96 97 98 99
    /* These two directories are ones QEMU processes use (so must match
     * the QEMU user/group */
    char *libDir;
    char *cacheDir;
100
    char *saveDir;
C
Chris Lalancette 已提交
101
    char *snapshotDir;
102 103 104 105 106

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

    bool spiceTLS;
113
    char *spiceTLSx509certdir;
114 115
    bool spiceSASL;
    char *spiceSASLdir;
116 117
    char *spiceListen;
    char *spicePassword;
118

119 120
    int remotePortMin;
    int remotePortMax;
121

122 123 124
    int webSocketPortMin;
    int webSocketPortMax;

125 126
    char *hugetlbfsMount;
    char *hugepagePath;
127
    char *bridgeHelperName;
128 129

    bool macFilter;
130

131 132
    bool relaxedACS;
    bool vncAllowHostAudio;
133
    bool nogfxAllowHostAudio;
134 135 136
    bool clearEmulatorCapabilities;
    bool allowDiskFormatProbing;
    bool setProcessName;
137

138
    int maxProcesses;
139
    int maxFiles;
140

141
    int maxQueuedJobs;
142

143
    char **securityDriverNames;
144 145
    bool securityDefaultConfined;
    bool securityRequireConfined;
146 147

    char *saveImageFormat;
148
    char *dumpImageFormat;
149
    char *snapshotImageFormat;
150

H
Hu Tao 已提交
151
    char *autoDumpPath;
152 153
    bool autoDumpBypassCache;
    bool autoStartBypassCache;
H
Hu Tao 已提交
154

155 156 157 158 159 160
    char *lockManagerName;

    int keepAliveInterval;
    unsigned int keepAliveCount;

    int seccompSandbox;
161 162 163

    /* The default for -incoming */
    char *migrationAddress;
164 165
    int migrationPortMin;
    int migrationPortMax;
166 167 168 169 170 171
};

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

172 173
    /* Require lock to get reference on 'config',
     * then lockless thereafter */
174 175
    virQEMUDriverConfigPtr config;

176
    /* Immutable pointer, self-locking APIs */
177 178
    virThreadPoolPtr workerPool;

179
    /* Atomic increment only */
180 181
    int nextvmid;

182
    /* Atomic inc/dec only */
183
    unsigned int nactive;
184

185
    /* Immutable pointers. Caller must provide locking */
186 187 188
    virStateInhibitCallback inhibitCallback;
    void *inhibitOpaque;

189
    /* Immutable pointer, self-locking APIs */
190
    virDomainObjListPtr domains;
191

192
    /* Immutable pointer */
193 194
    char *qemuImgBinary;

195
    /* Immutable pointer, lockless APIs. Pointless abstraction */
196 197
    ebtablesContext *ebtables;

198 199 200
    /* Require lock to get a reference on the object,
     * lockless access thereafter
     */
201 202
    virCapsPtr caps;

203
    /* Immutable pointer, Immutable object */
204
    virDomainXMLOptionPtr xmlopt;
205

206
    /* Immutable pointer, self-locking APIs */
207
    virQEMUCapsCachePtr qemuCapsCache;
208

209
    /* Immutable pointer, self-locking APIs */
210 211
    virDomainEventStatePtr domainEventState;

212
    /* Immutable pointer. self-locking APIs */
213 214
    virSecurityManagerPtr securityManager;

215 216 217
    /* Immutable pointers. Requires locks to be held before
     * calling APIs. activePciHostdevs must be locked before
     * inactivePciHostdevs */
218 219
    virPCIDeviceListPtr activePciHostdevs;
    virPCIDeviceListPtr inactivePciHostdevs;
220
    virUSBDeviceListPtr activeUsbHostdevs;
221
    virSCSIDeviceListPtr activeScsiHostdevs;
222

223
    /* Immutable pointer. Unsafe APIs. XXX */
224
    virHashTablePtr sharedDevices;
225

226
    /* Immutable pointer, self-locking APIs */
227
    virPortAllocatorPtr remotePorts;
228

229 230 231
    /* Immutable pointer, self-locking APIs */
    virPortAllocatorPtr webSocketPorts;

232 233 234
    /* Immutable pointer, self-locking APIs */
    virPortAllocatorPtr migrationPorts;

235
    /* Immutable pointer, lockless APIs*/
236
    virSysinfoDefPtr hostsysinfo;
237

238
    /* Immutable pointer. lockless access */
239
    virLockManagerPluginPtr lockManager;
240

241
    /* Immutable pointer, self-clocking APIs */
242
    virCloseCallbacksPtr closeCallbacks;
243 244
};

245 246 247 248 249 250 251 252 253 254 255
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;
};

256 257


258 259
void qemuDomainCmdlineDefFree(qemuDomainCmdlineDefPtr def);

260 261 262 263 264 265
virQEMUDriverConfigPtr virQEMUDriverConfigNew(bool privileged);

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

virQEMUDriverConfigPtr virQEMUDriverGetConfig(virQEMUDriverPtr driver);
266

267 268 269 270
virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver);
virCapsPtr virQEMUDriverGetCapabilities(virQEMUDriverPtr driver,
                                        bool refresh);

271 272 273 274
struct qemuDomainDiskInfo {
    bool removable;
    bool locked;
    bool tray_open;
275
    int io_status;
276 277
};

278 279
typedef struct _qemuSharedDeviceEntry qemuSharedDeviceEntry;
typedef qemuSharedDeviceEntry *qemuSharedDeviceEntryPtr;
280

281 282 283
bool qemuSharedDeviceEntryDomainExists(qemuSharedDeviceEntryPtr entry,
                                       const char *name,
                                       int *index)
284 285
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

286
char * qemuGetSharedDeviceKey(const char *disk_path)
287 288
    ATTRIBUTE_NONNULL(1);

289
void qemuSharedDeviceEntryFree(void *payload, const void *name)
290 291
    ATTRIBUTE_NONNULL(1);

292 293 294 295 296 297 298 299 300 301
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);

302
int qemuSetUnprivSGIO(virDomainDeviceDefPtr dev);
303

304
int qemuDriverAllocateID(virQEMUDriverPtr driver);
305 306
virDomainXMLOptionPtr virQEMUDriverCreateXMLConf(virQEMUDriverPtr driver);

307 308
int qemuTranslateDiskSourcePool(virConnectPtr conn,
                                virDomainDiskDefPtr def);
309

310
#endif /* __QEMUD_CONF_H */