qemu_conf.h 14.9 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>
28

29 30 31 32 33 34 35 36 37 38 39 40 41
# 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"
42
# include "bitmap.h"
43

44
# define qemudDebug(fmt, ...) do {} while(0)
45

46
# define QEMUD_CPUMASK_LEN CPU_SETSIZE
47

48 49
/* Internal flags to keep track of qemu command line capabilities */
enum qemud_cmd_flags {
50 51 52 53 54 55 56 57 58 59 60 61 62
    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 */
63
    QEMUD_CMD_FLAG_DRIVE_CACHE_V2    = (1 << 12), /* Is the cache= flag wanting new v2 values */
64
    QEMUD_CMD_FLAG_KVM               = (1 << 13), /* Whether KVM is compiled in */
65
    QEMUD_CMD_FLAG_DRIVE_FORMAT      = (1 << 14), /* Is -drive format= avail */
66
    QEMUD_CMD_FLAG_VGA               = (1 << 15), /* Is -vga avail */
67

E
Eric Blake 已提交
68
    /* features added in qemu-0.10.0 or later */
69 70 71
    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 */
72 73

    QEMUD_CMD_FLAG_PCIDEVICE     = (1 << 17), /* PCI device assignment only supported by qemu-kvm */
74
    QEMUD_CMD_FLAG_MEM_PATH      = (1 << 18), /* mmap'ped guest backing supported */
75
    QEMUD_CMD_FLAG_DRIVE_SERIAL  = (1 << 19), /* -driver serial=  available */
76
    QEMUD_CMD_FLAG_XEN_DOMID     = (1 << 20), /* -xen-domid (new style xen integration) */
77
    QEMUD_CMD_FLAG_MIGRATE_QEMU_UNIX = (1 << 21), /* Does qemu support unix domain sockets for migration? */
78
    QEMUD_CMD_FLAG_CHARDEV       = (1 << 22), /* Is the new -chardev arg available */
79
    QEMUD_CMD_FLAG_ENABLE_KVM    = (1 << 23), /* Is the -enable-kvm flag available to "enable KVM full virtualization support" */
80
    QEMUD_CMD_FLAG_MONITOR_JSON  = (1 << 24), /* JSON mode for monitor */
81
    QEMUD_CMD_FLAG_BALLOON       = (1 << 25), /* -balloon available */
82
    QEMUD_CMD_FLAG_DEVICE        = (1 << 26), /* Is the new -device arg available */
83
    QEMUD_CMD_FLAG_SDL           = (1 << 27), /* Is the new -sdl arg available */
84
    QEMUD_CMD_FLAG_SMP_TOPOLOGY  = (1 << 28), /* Is sockets=s,cores=c,threads=t available for -smp? */
85
    QEMUD_CMD_FLAG_NETDEV        = (1 << 29), /* The -netdev flag & netdev_add/remove monitor commands */
86
    QEMUD_CMD_FLAG_RTC           = (1 << 30), /* The -rtc flag for clock options */
E
Eric Blake 已提交
87 88
    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 */
89 90 91
    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) */
92
    QEMUD_CMD_FLAG_PCI_CONFIGFD  = (1LL << 36), /* pci-assign.configfd */
93
    QEMUD_CMD_FLAG_NODEFCONFIG   = (1LL << 37), /* -nodefconfig */
94
    QEMUD_CMD_FLAG_BOOT_MENU     = (1LL << 38), /* -boot menu=on support */
95
    QEMUD_CMD_FLAG_ENABLE_KQEMU  = (1LL << 39), /* -enable-kqemu flag */
96
    QEMUD_CMD_FLAG_FSDEV         = (1LL << 40), /* -fstype filesystem passthrough */
D
Daniel P. Berrange 已提交
97
    QEMUD_CMD_FLAG_NESTING       = (1LL << 41), /* -enable-nesting (SVM/VMX) */
98
    QEMUD_CMD_FLAG_NAME_PROCESS  = (1LL << 42), /* Is -name process= available */
99
    QEMUD_CMD_FLAG_DRIVE_READONLY    = (1LL << 43), /* -drive readonly=on|off */
100 101 102 103
};

/* Main driver state */
struct qemud_driver {
104
    virMutex lock;
105

106 107
    int privileged;

108 109
    uid_t user;
    gid_t group;
110
    int dynamicOwnership;
111

112
    unsigned int qemuVersion;
113
    int nextvmid;
114

115
    virCgroupPtr cgroup;
116 117 118
    int cgroupControllers;
    char **cgroupDeviceACL;

119
    virDomainObjList domains;
120

121
    brControl *brctl;
122 123
    /* These four directories are ones libvirtd uses (so must be root:root
     * to avoid security risk from QEMU processes */
124 125
    char *configDir;
    char *autostartDir;
126
    char *logDir;
127
    char *stateDir;
128 129 130 131
    /* These two directories are ones QEMU processes use (so must match
     * the QEMU user/group */
    char *libDir;
    char *cacheDir;
132
    char *saveDir;
C
Chris Lalancette 已提交
133
    char *snapshotDir;
134 135
    unsigned int vncTLS : 1;
    unsigned int vncTLSx509verify : 1;
136
    unsigned int vncSASL : 1;
D
Daniel P. Berrange 已提交
137
    char *vncTLSx509certdir;
138
    char *vncListen;
139
    char *vncPassword;
140
    char *vncSASLdir;
141 142
    char *hugetlbfs_mount;
    char *hugepage_path;
143

144 145 146
    unsigned int macFilter : 1;
    ebtablesContext *ebtables;

147
    unsigned int relaxedACS : 1;
148
    unsigned int vncAllowHostAudio : 1;
149
    unsigned int clearEmulatorCapabilities : 1;
150
    unsigned int allowDiskFormatProbing : 1;
151
    unsigned int setProcessName : 1;
152

153
    virCapsPtr caps;
154 155 156

    /* An array of callbacks */
    virDomainEventCallbackListPtr domainEventCallbacks;
157 158 159
    virDomainEventQueuePtr domainEventQueue;
    int domainEventTimer;
    int domainEventDispatching;
160 161 162

    char *securityDriverName;
    virSecurityDriverPtr securityDriver;
163 164
    virSecurityDriverPtr securityPrimaryDriver;
    virSecurityDriverPtr securitySecondaryDriver;
165 166

    char *saveImageFormat;
167 168

    pciDeviceList *activePciHostdevs;
169 170

    virBitmapPtr reservedVNCPorts;
171 172
};

173 174
typedef struct _qemuDomainPCIAddressSet qemuDomainPCIAddressSet;
typedef qemuDomainPCIAddressSet *qemuDomainPCIAddressSetPtr;
175

176 177 178 179 180 181 182 183 184 185 186
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 已提交
187
/* Port numbers used for KVM migration. */
188 189
# define QEMUD_MIGRATION_FIRST_PORT 49152
# define QEMUD_MIGRATION_NUM_PORTS 64
190

191
/* Config type for XML import/export conversions */
192
# define QEMU_CONFIG_FORMAT_ARGV "qemu-argv"
193

194 195
# define QEMU_DRIVE_HOST_PREFIX "drive-"
# define QEMU_VIRTIO_SERIAL_PREFIX "virtio-serial"
196
# define QEMU_FSDEV_HOST_PREFIX "fsdev-"
197

198
# define qemuReportError(code, ...)                                      \
199
    virReportErrorHelper(NULL, VIR_FROM_QEMU, code, __FILE__,           \
200
                         __FUNCTION__, __LINE__, __VA_ARGS__)
201 202


D
Daniel P. Berrange 已提交
203 204
int qemudLoadDriverConfig(struct qemud_driver *driver,
                          const char *filename);
205

206
virCapsPtr  qemudCapsInit               (virCapsPtr old_caps);
207

208
int         qemudExtractVersion         (struct qemud_driver *driver);
209
int         qemudExtractVersionInfo     (const char *qemu,
210
                                         unsigned int *version,
211
                                         unsigned long long *qemuCmdFlags);
D
Daniel P. Berrange 已提交
212

213 214
int         qemudParseHelpStr           (const char *qemu,
                                         const char *str,
215
                                         unsigned long long *qemuCmdFlags,
216 217 218 219
                                         unsigned int *version,
                                         unsigned int *is_kvm,
                                         unsigned int *kvm_version);

220
int         qemudBuildCommandLine       (virConnectPtr conn,
221
                                         struct qemud_driver *driver,
222
                                         virDomainDefPtr def,
223
                                         virDomainChrDefPtr monitor_chr,
D
Daniel P. Berrange 已提交
224
                                         int monitor_json,
225
                                         unsigned long long qemuCmdFlags,
226 227
                                         const char ***retargv,
                                         const char ***retenv,
228 229
                                         int **vmfds,
                                         int *nvmfds,
C
Chris Lalancette 已提交
230 231
                                         const char *migrateFrom,
                                         virDomainSnapshotObjPtr current_snapshot)
232
    ATTRIBUTE_NONNULL(1);
233

234
/* With vlan == -1, use netdev syntax, else old hostnet */
235
char * qemuBuildHostNetStr(virDomainNetDefPtr net,
236 237
                           char type_sep,
                           int vlan,
238 239
                           const char *tapfd,
                           const char *vhostfd);
M
Mark McLoughlin 已提交
240

241
/* Legacy, pre device support */
242
char * qemuBuildNicStr(virDomainNetDefPtr net,
243 244 245 246
                       const char *prefix,
                       int vlan);

/* Current, best practice */
247
char * qemuBuildNicDevStr(virDomainNetDefPtr net,
248
                          int vlan);
249

250 251 252
char *qemuDeviceDriveHostAlias(virDomainDiskDefPtr disk,
                               unsigned long long qemudCmdFlags);

253 254 255
/* Both legacy & current support */
char *qemuBuildDriveStr(virDomainDiskDefPtr disk,
                        int bootable,
256
                        unsigned long long qemuCmdFlags);
257 258
char *qemuBuildFSStr(virDomainFSDefPtr fs,
                     unsigned long long qemuCmdFlags);
259 260

/* Current, best practice */
261
char * qemuBuildDriveDevStr(virDomainDiskDefPtr disk);
262
char * qemuBuildFSDevStr(virDomainFSDefPtr fs);
263 264 265 266 267
/* Current, best practice */
char * qemuBuildControllerDevStr(virDomainControllerDefPtr def);

char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev);

268 269
char * qemuBuildMemballoonDevStr(virDomainMemballoonDefPtr dev);

270 271 272 273
char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev);

char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound);

274 275 276
/* Legacy, pre device support */
char * qemuBuildPCIHostdevPCIDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
277 278 279 280
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev,
                                 const char *configfd);

int qemudOpenPCIConfig(virDomainHostdevDefPtr dev);
281

282
/* Current, best practice */
283
char * qemuBuildChrChardevStr(virDomainChrDefPtr dev);
284
/* Legacy, pre device support */
285
char * qemuBuildChrArgStr(virDomainChrDefPtr dev, const char *prefix);
M
Mark McLoughlin 已提交
286

287 288
char * qemuBuildVirtioSerialPortDevStr(virDomainChrDefPtr dev);

289 290 291 292 293
/* Legacy, pre device support */
char * qemuBuildUSBHostdevUsbDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
char * qemuBuildUSBHostdevDevStr(virDomainHostdevDefPtr dev);

294 295


296 297 298
int         qemudNetworkIfaceConnect    (virConnectPtr conn,
                                         struct qemud_driver *driver,
                                         virDomainNetDefPtr net,
299 300
                                         unsigned long long qemuCmdFlags)
    ATTRIBUTE_NONNULL(1);
301

302 303 304 305
int
qemudOpenVhostNet(virDomainNetDefPtr net,
                  unsigned long long qemuCmdFlags);

306
int qemudPhysIfaceConnect(virConnectPtr conn,
S
Stefan Berger 已提交
307
                          struct qemud_driver *driver,
308
                          virDomainNetDefPtr net,
309 310
                          unsigned long long qemuCmdFlags,
                          const unsigned char *vmuuid);
311

312 313 314 315
int         qemudProbeMachineTypes      (const char *binary,
                                         virCapsGuestMachinePtr **machines,
                                         int *nmachines);

316
int         qemudProbeCPUModels         (const char *qemu,
317
                                         unsigned long long qemuCmdFlags,
318 319 320 321
                                         const char *arch,
                                         unsigned int *count,
                                         const char ***cpus);

322 323 324
int         qemudCanonicalizeMachine    (struct qemud_driver *driver,
                                         virDomainDefPtr def);

325
virDomainDefPtr qemuParseCommandLine(virCapsPtr caps,
326 327
                                     const char **progenv,
                                     const char **progargv);
328
virDomainDefPtr qemuParseCommandLineString(virCapsPtr caps,
329 330
                                           const char *args);

331
qemuDomainPCIAddressSetPtr qemuDomainPCIAddressSetCreate(virDomainDefPtr def);
332 333 334 335
int qemuDomainPCIAddressReserveSlot(qemuDomainPCIAddressSetPtr addrs,
                                    int slot);
int qemuDomainPCIAddressReserveAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
336 337
int qemuDomainPCIAddressSetNextAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
338 339 340 341 342
int qemuDomainPCIAddressEnsureAddr(qemuDomainPCIAddressSetPtr addrs,
                                   virDomainDeviceInfoPtr dev);
int qemuDomainPCIAddressReleaseAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);

343 344 345
void qemuDomainPCIAddressSetFree(qemuDomainPCIAddressSetPtr addrs);
int  qemuAssignDevicePCISlots(virDomainDefPtr def, qemuDomainPCIAddressSetPtr addrs);

346
int qemuDomainNetVLAN(virDomainNetDefPtr def);
347
int qemuAssignDeviceNetAlias(virDomainDefPtr def, virDomainNetDefPtr net, int idx);
348
int qemuAssignDeviceDiskAlias(virDomainDiskDefPtr def, unsigned long long qemuCmdFlags);
349 350
int qemuAssignDeviceHostdevAlias(virDomainDefPtr def, virDomainHostdevDefPtr net, int idx);
int qemuAssignDeviceControllerAlias(virDomainControllerDefPtr controller);
351

352 353 354 355 356 357
int
qemuParseKeywords(const char *str,
                  char ***retkeywords,
                  char ***retvalues,
                  int allowEmptyValue);

358

359
#endif /* __QEMUD_CONF_H */