qemu_conf.h 15.4 KB
Newer Older
D
Daniel P. Berrange 已提交
1
/*
2
 * qemu_conf.h: QEMU configuration management
D
Daniel P. Berrange 已提交
3
 *
E
Eric Blake 已提交
4
 * Copyright (C) 2006-2007, 2009-2010 Red Hat, Inc.
D
Daniel P. Berrange 已提交
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
 * 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
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
 *
 * 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>
E
Eric Blake 已提交
28
# include <stdbool.h>
29

30 31 32 33 34 35 36 37 38 39 40 41 42
# include "ebtables.h"
# include "internal.h"
# include "bridge.h"
# include "capabilities.h"
# include "network_conf.h"
# include "domain_conf.h"
# include "domain_event.h"
# include "threads.h"
# include "security/security_driver.h"
# include "cgroup.h"
# include "pci.h"
# include "cpu_conf.h"
# include "driver.h"
43
# include "bitmap.h"
44
# include "macvtap.h"
E
Eric Blake 已提交
45
# include "command.h"
H
Hu Tao 已提交
46
# include "threadpool.h"
47

48
# define QEMUD_CPUMASK_LEN CPU_SETSIZE
49

50 51
/* Internal flags to keep track of qemu command line capabilities */
enum qemud_cmd_flags {
52 53 54 55 56 57 58 59 60 61 62 63 64
    QEMUD_CMD_FLAG_KQEMU          = (1 << 0), /* Whether KQEMU is compiled in */
    QEMUD_CMD_FLAG_VNC_COLON      = (1 << 1), /* Does the VNC take just port, or address + display */
    QEMUD_CMD_FLAG_NO_REBOOT      = (1 << 2), /* Is the -no-reboot flag available */
    QEMUD_CMD_FLAG_DRIVE          = (1 << 3), /* Is the new -drive arg available */
    QEMUD_CMD_FLAG_DRIVE_BOOT     = (1 << 4), /* Does -drive support boot=on */
    QEMUD_CMD_FLAG_NAME           = (1 << 5), /* Is the -name flag available */
    QEMUD_CMD_FLAG_UUID           = (1 << 6), /* Is the -uuid flag available */
    QEMUD_CMD_FLAG_DOMID          = (1 << 7), /* Xenner only, special -domid flag available */
    QEMUD_CMD_FLAG_VNET_HDR        = (1 << 8),
    QEMUD_CMD_FLAG_MIGRATE_KVM_STDIO = (1 << 9),  /* Original migration code from KVM. Also had tcp, but we can't use that
                                                   * since it had a design bug blocking the entire monitor console */
    QEMUD_CMD_FLAG_MIGRATE_QEMU_TCP  = (1 << 10), /* New migration syntax after merge to QEMU with TCP transport */
    QEMUD_CMD_FLAG_MIGRATE_QEMU_EXEC = (1 << 11), /* New migration syntax after merge to QEMU with EXEC transport */
65
    QEMUD_CMD_FLAG_DRIVE_CACHE_V2    = (1 << 12), /* Is the cache= flag wanting new v2 values */
66
    QEMUD_CMD_FLAG_KVM               = (1 << 13), /* Whether KVM is compiled in */
67
    QEMUD_CMD_FLAG_DRIVE_FORMAT      = (1 << 14), /* Is -drive format= avail */
68
    QEMUD_CMD_FLAG_VGA               = (1 << 15), /* Is -vga avail */
69

E
Eric Blake 已提交
70
    /* features added in qemu-0.10.0 or later */
71 72 73
    QEMUD_CMD_FLAG_0_10         = (1 << 16),
    QEMUD_CMD_FLAG_NET_NAME     = QEMUD_CMD_FLAG_0_10, /* -net ...,name=str */
    QEMUD_CMD_FLAG_HOST_NET_ADD = QEMUD_CMD_FLAG_0_10, /* host_net_add monitor command */
74 75

    QEMUD_CMD_FLAG_PCIDEVICE     = (1 << 17), /* PCI device assignment only supported by qemu-kvm */
76
    QEMUD_CMD_FLAG_MEM_PATH      = (1 << 18), /* mmap'ped guest backing supported */
77
    QEMUD_CMD_FLAG_DRIVE_SERIAL  = (1 << 19), /* -driver serial=  available */
78
    QEMUD_CMD_FLAG_XEN_DOMID     = (1 << 20), /* -xen-domid (new style xen integration) */
79
    QEMUD_CMD_FLAG_MIGRATE_QEMU_UNIX = (1 << 21), /* Does qemu support unix domain sockets for migration? */
80
    QEMUD_CMD_FLAG_CHARDEV       = (1 << 22), /* Is the new -chardev arg available */
81
    QEMUD_CMD_FLAG_ENABLE_KVM    = (1 << 23), /* Is the -enable-kvm flag available to "enable KVM full virtualization support" */
82
    QEMUD_CMD_FLAG_MONITOR_JSON  = (1 << 24), /* JSON mode for monitor */
83
    QEMUD_CMD_FLAG_BALLOON       = (1 << 25), /* -balloon available */
84
    QEMUD_CMD_FLAG_DEVICE        = (1 << 26), /* Is the new -device arg available */
85
    QEMUD_CMD_FLAG_SDL           = (1 << 27), /* Is the new -sdl arg available */
86
    QEMUD_CMD_FLAG_SMP_TOPOLOGY  = (1 << 28), /* Is sockets=s,cores=c,threads=t available for -smp? */
87
    QEMUD_CMD_FLAG_NETDEV        = (1 << 29), /* The -netdev flag & netdev_add/remove monitor commands */
88
    QEMUD_CMD_FLAG_RTC           = (1 << 30), /* The -rtc flag for clock options */
E
Eric Blake 已提交
89 90
    QEMUD_CMD_FLAG_VNET_HOST     = (1LL << 31), /* vnet-host support is available in qemu */
    QEMUD_CMD_FLAG_RTC_TD_HACK   = (1LL << 32), /* -rtc-td-hack available */
91 92 93
    QEMUD_CMD_FLAG_NO_HPET       = (1LL << 33), /* -no-hpet flag is supported */
    QEMUD_CMD_FLAG_NO_KVM_PIT    = (1LL << 34), /* -no-kvm-pit-reinjection supported */
    QEMUD_CMD_FLAG_TDF           = (1LL << 35), /* -tdf flag (user-mode pit catchup) */
94
    QEMUD_CMD_FLAG_PCI_CONFIGFD  = (1LL << 36), /* pci-assign.configfd */
95
    QEMUD_CMD_FLAG_NODEFCONFIG   = (1LL << 37), /* -nodefconfig */
96
    QEMUD_CMD_FLAG_BOOT_MENU     = (1LL << 38), /* -boot menu=on support */
97
    QEMUD_CMD_FLAG_ENABLE_KQEMU  = (1LL << 39), /* -enable-kqemu flag */
98
    QEMUD_CMD_FLAG_FSDEV         = (1LL << 40), /* -fstype filesystem passthrough */
D
Daniel P. Berrange 已提交
99
    QEMUD_CMD_FLAG_NESTING       = (1LL << 41), /* -enable-nesting (SVM/VMX) */
100
    QEMUD_CMD_FLAG_NAME_PROCESS  = (1LL << 42), /* Is -name process= available */
101 102
    QEMUD_CMD_FLAG_DRIVE_READONLY= (1LL << 43), /* -drive readonly=on|off */
    QEMUD_CMD_FLAG_SMBIOS_TYPE   = (1LL << 44), /* Is -smbios type= available */
103
    QEMUD_CMD_FLAG_VGA_QXL       = (1LL << 45), /* The 'qxl' arg for '-vga' */
104
    QEMUD_CMD_FLAG_SPICE         = (1LL << 46), /* Is -spice avail */
105
    QEMUD_CMD_FLAG_VGA_NONE      = (1LL << 47), /* The 'none' arg for '-vga' */
106 107 108 109
};

/* Main driver state */
struct qemud_driver {
110
    virMutex lock;
111

H
Hu Tao 已提交
112 113
    virThreadPoolPtr workerPool;

114 115
    int privileged;

116 117
    uid_t user;
    gid_t group;
118
    int dynamicOwnership;
119

120
    unsigned int qemuVersion;
121
    int nextvmid;
122

123
    virCgroupPtr cgroup;
124 125 126
    int cgroupControllers;
    char **cgroupDeviceACL;

127
    virDomainObjList domains;
128

129
    brControl *brctl;
130 131
    /* These four directories are ones libvirtd uses (so must be root:root
     * to avoid security risk from QEMU processes */
132 133
    char *configDir;
    char *autostartDir;
134
    char *logDir;
135
    char *stateDir;
136 137 138 139
    /* These two directories are ones QEMU processes use (so must match
     * the QEMU user/group */
    char *libDir;
    char *cacheDir;
140
    char *saveDir;
C
Chris Lalancette 已提交
141
    char *snapshotDir;
142 143
    unsigned int vncTLS : 1;
    unsigned int vncTLSx509verify : 1;
144
    unsigned int vncSASL : 1;
D
Daniel P. Berrange 已提交
145
    char *vncTLSx509certdir;
146
    char *vncListen;
147
    char *vncPassword;
148
    char *vncSASLdir;
149 150 151 152
    unsigned int spiceTLS : 1;
    char *spiceTLSx509certdir;
    char *spiceListen;
    char *spicePassword;
153 154
    char *hugetlbfs_mount;
    char *hugepage_path;
155

156 157 158
    unsigned int macFilter : 1;
    ebtablesContext *ebtables;

159
    unsigned int relaxedACS : 1;
160
    unsigned int vncAllowHostAudio : 1;
161
    unsigned int clearEmulatorCapabilities : 1;
162
    unsigned int allowDiskFormatProbing : 1;
163
    unsigned int setProcessName : 1;
164

165
    virCapsPtr caps;
166 167 168

    /* An array of callbacks */
    virDomainEventCallbackListPtr domainEventCallbacks;
169 170 171
    virDomainEventQueuePtr domainEventQueue;
    int domainEventTimer;
    int domainEventDispatching;
172 173 174

    char *securityDriverName;
    virSecurityDriverPtr securityDriver;
175 176
    virSecurityDriverPtr securityPrimaryDriver;
    virSecurityDriverPtr securitySecondaryDriver;
177 178

    char *saveImageFormat;
179
    char *dumpImageFormat;
180

H
Hu Tao 已提交
181 182
    char *autoDumpPath;

183
    pciDeviceList *activePciHostdevs;
184 185

    virBitmapPtr reservedVNCPorts;
186 187

    virSysinfoDefPtr hostsysinfo;
188 189
};

190 191
typedef struct _qemuDomainPCIAddressSet qemuDomainPCIAddressSet;
typedef qemuDomainPCIAddressSet *qemuDomainPCIAddressSetPtr;
192

193 194 195 196 197 198 199 200 201 202 203
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 已提交
204
/* Port numbers used for KVM migration. */
205 206
# define QEMUD_MIGRATION_FIRST_PORT 49152
# define QEMUD_MIGRATION_NUM_PORTS 64
207

208
/* Config type for XML import/export conversions */
209
# define QEMU_CONFIG_FORMAT_ARGV "qemu-argv"
210

211 212
# define QEMU_DRIVE_HOST_PREFIX "drive-"
# define QEMU_VIRTIO_SERIAL_PREFIX "virtio-serial"
213
# define QEMU_FSDEV_HOST_PREFIX "fsdev-"
214

215
# define qemuReportError(code, ...)                                      \
216
    virReportErrorHelper(NULL, VIR_FROM_QEMU, code, __FILE__,           \
217
                         __FUNCTION__, __LINE__, __VA_ARGS__)
218 219


D
Daniel P. Berrange 已提交
220 221
int qemudLoadDriverConfig(struct qemud_driver *driver,
                          const char *filename);
222

223
virCapsPtr  qemudCapsInit               (virCapsPtr old_caps);
224

225
int         qemudExtractVersion         (struct qemud_driver *driver);
226
int         qemudExtractVersionInfo     (const char *qemu,
227
                                         unsigned int *version,
228
                                         unsigned long long *qemuCmdFlags);
D
Daniel P. Berrange 已提交
229

230 231
int         qemudParseHelpStr           (const char *qemu,
                                         const char *str,
232
                                         unsigned long long *qemuCmdFlags,
233 234 235 236
                                         unsigned int *version,
                                         unsigned int *is_kvm,
                                         unsigned int *kvm_version);

E
Eric Blake 已提交
237
virCommandPtr qemudBuildCommandLine     (virConnectPtr conn,
238
                                         struct qemud_driver *driver,
239
                                         virDomainDefPtr def,
240
                                         virDomainChrDefPtr monitor_chr,
E
Eric Blake 已提交
241
                                         bool monitor_json,
242
                                         unsigned long long qemuCmdFlags,
C
Chris Lalancette 已提交
243
                                         const char *migrateFrom,
244 245
                                         virDomainSnapshotObjPtr current_snapshot,
                                         enum virVMOperationType vmop)
246
    ATTRIBUTE_NONNULL(1);
247

248
/* With vlan == -1, use netdev syntax, else old hostnet */
249
char * qemuBuildHostNetStr(virDomainNetDefPtr net,
250 251
                           char type_sep,
                           int vlan,
252 253
                           const char *tapfd,
                           const char *vhostfd);
M
Mark McLoughlin 已提交
254

255
/* Legacy, pre device support */
256
char * qemuBuildNicStr(virDomainNetDefPtr net,
257 258 259 260
                       const char *prefix,
                       int vlan);

/* Current, best practice */
261
char * qemuBuildNicDevStr(virDomainNetDefPtr net,
262
                          int vlan);
263

264 265 266
char *qemuDeviceDriveHostAlias(virDomainDiskDefPtr disk,
                               unsigned long long qemudCmdFlags);

267 268 269
/* Both legacy & current support */
char *qemuBuildDriveStr(virDomainDiskDefPtr disk,
                        int bootable,
270
                        unsigned long long qemuCmdFlags);
271 272
char *qemuBuildFSStr(virDomainFSDefPtr fs,
                     unsigned long long qemuCmdFlags);
273 274

/* Current, best practice */
275
char * qemuBuildDriveDevStr(virDomainDiskDefPtr disk);
276
char * qemuBuildFSDevStr(virDomainFSDefPtr fs);
277 278 279 280 281
/* Current, best practice */
char * qemuBuildControllerDevStr(virDomainControllerDefPtr def);

char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev);

282 283
char * qemuBuildMemballoonDevStr(virDomainMemballoonDefPtr dev);

284 285 286 287
char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev);

char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound);

288 289 290
/* Legacy, pre device support */
char * qemuBuildPCIHostdevPCIDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
291 292 293 294
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev,
                                 const char *configfd);

int qemudOpenPCIConfig(virDomainHostdevDefPtr dev);
295

296
/* Current, best practice */
297
char * qemuBuildChrChardevStr(virDomainChrDefPtr dev);
298
/* Legacy, pre device support */
299
char * qemuBuildChrArgStr(virDomainChrDefPtr dev, const char *prefix);
M
Mark McLoughlin 已提交
300

301 302
char * qemuBuildVirtioSerialPortDevStr(virDomainChrDefPtr dev);

303 304 305 306 307
/* Legacy, pre device support */
char * qemuBuildUSBHostdevUsbDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
char * qemuBuildUSBHostdevDevStr(virDomainHostdevDefPtr dev);

308 309


310 311 312
int         qemudNetworkIfaceConnect    (virConnectPtr conn,
                                         struct qemud_driver *driver,
                                         virDomainNetDefPtr net,
313 314
                                         unsigned long long qemuCmdFlags)
    ATTRIBUTE_NONNULL(1);
315

316 317 318 319
int
qemudOpenVhostNet(virDomainNetDefPtr net,
                  unsigned long long qemuCmdFlags);

320
int qemudPhysIfaceConnect(virConnectPtr conn,
S
Stefan Berger 已提交
321
                          struct qemud_driver *driver,
322
                          virDomainNetDefPtr net,
323
                          unsigned long long qemuCmdFlags,
324 325
                          const unsigned char *vmuuid,
                          enum virVMOperationType vmop);
326

327 328 329 330
int         qemudProbeMachineTypes      (const char *binary,
                                         virCapsGuestMachinePtr **machines,
                                         int *nmachines);

331
int         qemudProbeCPUModels         (const char *qemu,
332
                                         unsigned long long qemuCmdFlags,
333 334 335 336
                                         const char *arch,
                                         unsigned int *count,
                                         const char ***cpus);

337 338 339
int         qemudCanonicalizeMachine    (struct qemud_driver *driver,
                                         virDomainDefPtr def);

340
virDomainDefPtr qemuParseCommandLine(virCapsPtr caps,
341 342
                                     const char **progenv,
                                     const char **progargv);
343
virDomainDefPtr qemuParseCommandLineString(virCapsPtr caps,
344 345
                                           const char *args);

346
qemuDomainPCIAddressSetPtr qemuDomainPCIAddressSetCreate(virDomainDefPtr def);
347 348 349 350
int qemuDomainPCIAddressReserveSlot(qemuDomainPCIAddressSetPtr addrs,
                                    int slot);
int qemuDomainPCIAddressReserveAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
351 352
int qemuDomainPCIAddressSetNextAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
353 354 355 356 357
int qemuDomainPCIAddressEnsureAddr(qemuDomainPCIAddressSetPtr addrs,
                                   virDomainDeviceInfoPtr dev);
int qemuDomainPCIAddressReleaseAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);

358 359 360
void qemuDomainPCIAddressSetFree(qemuDomainPCIAddressSetPtr addrs);
int  qemuAssignDevicePCISlots(virDomainDefPtr def, qemuDomainPCIAddressSetPtr addrs);

361
int qemuDomainNetVLAN(virDomainNetDefPtr def);
362
int qemuAssignDeviceNetAlias(virDomainDefPtr def, virDomainNetDefPtr net, int idx);
363
int qemuAssignDeviceDiskAlias(virDomainDiskDefPtr def, unsigned long long qemuCmdFlags);
364 365
int qemuAssignDeviceHostdevAlias(virDomainDefPtr def, virDomainHostdevDefPtr net, int idx);
int qemuAssignDeviceControllerAlias(virDomainControllerDefPtr controller);
366

367 368 369 370 371 372
int
qemuParseKeywords(const char *str,
                  char ***retkeywords,
                  char ***retvalues,
                  int allowEmptyValue);

373

374
#endif /* __QEMUD_CONF_H */