qemu_conf.h 13.8 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 95 96 97
};

/* Main driver state */
struct qemud_driver {
98
    virMutex lock;
99

100 101
    int privileged;

102 103
    uid_t user;
    gid_t group;
104
    int dynamicOwnership;
105

106
    unsigned int qemuVersion;
107
    int nextvmid;
108

109
    virCgroupPtr cgroup;
110 111 112
    int cgroupControllers;
    char **cgroupDeviceACL;

113
    virDomainObjList domains;
114

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

138 139 140
    unsigned int macFilter : 1;
    ebtablesContext *ebtables;

141
    unsigned int relaxedACS : 1;
142
    unsigned int vncAllowHostAudio : 1;
143
    unsigned int clearEmulatorCapabilities : 1;
144

145
    virCapsPtr caps;
146 147 148

    /* An array of callbacks */
    virDomainEventCallbackListPtr domainEventCallbacks;
149 150 151
    virDomainEventQueuePtr domainEventQueue;
    int domainEventTimer;
    int domainEventDispatching;
152 153 154

    char *securityDriverName;
    virSecurityDriverPtr securityDriver;
155 156
    virSecurityDriverPtr securityPrimaryDriver;
    virSecurityDriverPtr securitySecondaryDriver;
157 158

    char *saveImageFormat;
159 160

    pciDeviceList *activePciHostdevs;
161 162

    virBitmapPtr reservedVNCPorts;
163 164
};

165 166
typedef struct _qemuDomainPCIAddressSet qemuDomainPCIAddressSet;
typedef qemuDomainPCIAddressSet *qemuDomainPCIAddressSetPtr;
167

D
Daniel Veillard 已提交
168
/* Port numbers used for KVM migration. */
169 170
# define QEMUD_MIGRATION_FIRST_PORT 49152
# define QEMUD_MIGRATION_NUM_PORTS 64
171

172
/* Config type for XML import/export conversions */
173
# define QEMU_CONFIG_FORMAT_ARGV "qemu-argv"
174

175 176
# define QEMU_DRIVE_HOST_PREFIX "drive-"
# define QEMU_VIRTIO_SERIAL_PREFIX "virtio-serial"
177

178
# define qemuReportError(code, ...)                                      \
179
    virReportErrorHelper(NULL, VIR_FROM_QEMU, code, __FILE__,           \
180
                         __FUNCTION__, __LINE__, __VA_ARGS__)
181 182


D
Daniel P. Berrange 已提交
183 184
int qemudLoadDriverConfig(struct qemud_driver *driver,
                          const char *filename);
185

186
virCapsPtr  qemudCapsInit               (virCapsPtr old_caps);
187

188
int         qemudExtractVersion         (struct qemud_driver *driver);
189
int         qemudExtractVersionInfo     (const char *qemu,
190
                                         unsigned int *version,
191
                                         unsigned long long *qemuCmdFlags);
D
Daniel P. Berrange 已提交
192

193 194
int         qemudParseHelpStr           (const char *qemu,
                                         const char *str,
195
                                         unsigned long long *qemuCmdFlags,
196 197 198 199
                                         unsigned int *version,
                                         unsigned int *is_kvm,
                                         unsigned int *kvm_version);

200
int         qemudBuildCommandLine       (virConnectPtr conn,
201
                                         struct qemud_driver *driver,
202
                                         virDomainDefPtr def,
203
                                         virDomainChrDefPtr monitor_chr,
D
Daniel P. Berrange 已提交
204
                                         int monitor_json,
205
                                         unsigned long long qemuCmdFlags,
206 207
                                         const char ***retargv,
                                         const char ***retenv,
208 209
                                         int **vmfds,
                                         int *nvmfds,
C
Chris Lalancette 已提交
210 211
                                         const char *migrateFrom,
                                         virDomainSnapshotObjPtr current_snapshot)
212
    ATTRIBUTE_NONNULL(1);
213

214
/* With vlan == -1, use netdev syntax, else old hostnet */
215
char * qemuBuildHostNetStr(virDomainNetDefPtr net,
216 217
                           char type_sep,
                           int vlan,
218 219
                           const char *tapfd,
                           const char *vhostfd);
M
Mark McLoughlin 已提交
220

221
/* Legacy, pre device support */
222
char * qemuBuildNicStr(virDomainNetDefPtr net,
223 224 225 226
                       const char *prefix,
                       int vlan);

/* Current, best practice */
227
char * qemuBuildNicDevStr(virDomainNetDefPtr net,
228
                          int vlan);
229

230 231 232
char *qemuDeviceDriveHostAlias(virDomainDiskDefPtr disk,
                               unsigned long long qemudCmdFlags);

233 234 235
/* Both legacy & current support */
char *qemuBuildDriveStr(virDomainDiskDefPtr disk,
                        int bootable,
236
                        unsigned long long qemuCmdFlags);
237 238

/* Current, best practice */
239
char * qemuBuildDriveDevStr(virDomainDiskDefPtr disk);
240 241 242 243 244 245 246 247 248
/* Current, best practice */
char * qemuBuildControllerDevStr(virDomainControllerDefPtr def);

char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev);

char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev);

char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound);

249 250 251
/* Legacy, pre device support */
char * qemuBuildPCIHostdevPCIDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
252 253 254 255
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev,
                                 const char *configfd);

int qemudOpenPCIConfig(virDomainHostdevDefPtr dev);
256

257
/* Current, best practice */
258
char * qemuBuildChrChardevStr(virDomainChrDefPtr dev);
259
/* Legacy, pre device support */
260
char * qemuBuildChrArgStr(virDomainChrDefPtr dev, const char *prefix);
M
Mark McLoughlin 已提交
261

262 263
char * qemuBuildVirtioSerialPortDevStr(virDomainChrDefPtr dev);

264 265 266 267 268
/* Legacy, pre device support */
char * qemuBuildUSBHostdevUsbDevStr(virDomainHostdevDefPtr dev);
/* Current, best practice */
char * qemuBuildUSBHostdevDevStr(virDomainHostdevDefPtr dev);

269 270


271 272 273
int         qemudNetworkIfaceConnect    (virConnectPtr conn,
                                         struct qemud_driver *driver,
                                         virDomainNetDefPtr net,
274 275
                                         unsigned long long qemuCmdFlags)
    ATTRIBUTE_NONNULL(1);
276

277 278 279 280
int
qemudOpenVhostNet(virDomainNetDefPtr net,
                  unsigned long long qemuCmdFlags);

281
int qemudPhysIfaceConnect(virConnectPtr conn,
S
Stefan Berger 已提交
282
                          struct qemud_driver *driver,
283
                          virDomainNetDefPtr net,
284 285
                          unsigned long long qemuCmdFlags,
                          const unsigned char *vmuuid);
286

287 288 289 290
int         qemudProbeMachineTypes      (const char *binary,
                                         virCapsGuestMachinePtr **machines,
                                         int *nmachines);

291
int         qemudProbeCPUModels         (const char *qemu,
292
                                         unsigned long long qemuCmdFlags,
293 294 295 296
                                         const char *arch,
                                         unsigned int *count,
                                         const char ***cpus);

297 298 299
int         qemudCanonicalizeMachine    (struct qemud_driver *driver,
                                         virDomainDefPtr def);

300
virDomainDefPtr qemuParseCommandLine(virCapsPtr caps,
301 302
                                     const char **progenv,
                                     const char **progargv);
303
virDomainDefPtr qemuParseCommandLineString(virCapsPtr caps,
304 305
                                           const char *args);

306
qemuDomainPCIAddressSetPtr qemuDomainPCIAddressSetCreate(virDomainDefPtr def);
307 308 309 310
int qemuDomainPCIAddressReserveSlot(qemuDomainPCIAddressSetPtr addrs,
                                    int slot);
int qemuDomainPCIAddressReserveAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
311 312
int qemuDomainPCIAddressSetNextAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);
313 314 315 316 317
int qemuDomainPCIAddressEnsureAddr(qemuDomainPCIAddressSetPtr addrs,
                                   virDomainDeviceInfoPtr dev);
int qemuDomainPCIAddressReleaseAddr(qemuDomainPCIAddressSetPtr addrs,
                                    virDomainDeviceInfoPtr dev);

318 319 320
void qemuDomainPCIAddressSetFree(qemuDomainPCIAddressSetPtr addrs);
int  qemuAssignDevicePCISlots(virDomainDefPtr def, qemuDomainPCIAddressSetPtr addrs);

321
int qemuDomainNetVLAN(virDomainNetDefPtr def);
322
int qemuAssignDeviceNetAlias(virDomainDefPtr def, virDomainNetDefPtr net, int idx);
323
int qemuAssignDeviceDiskAlias(virDomainDiskDefPtr def, unsigned long long qemuCmdFlags);
324 325
int qemuAssignDeviceHostdevAlias(virDomainDefPtr def, virDomainHostdevDefPtr net, int idx);
int qemuAssignDeviceControllerAlias(virDomainControllerDefPtr controller);
326

327 328 329 330 331 332
int
qemuParseKeywords(const char *str,
                  char ***retkeywords,
                  char ***retvalues,
                  int allowEmptyValue);

333

334
#endif /* __QEMUD_CONF_H */