mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
Rename 'qemuCapsXXX' to 'virQEMUCapsXXX'
To avoid confusion between 'virCapsPtr' and 'qemuCapsPtr' do some renaming of various fucntions/variables. All instances of 'qemuCapsPtr' are renamed to 'qemuCaps'. To avoid that clashing with the 'qemuCaps' typedef though, rename the latter to virQEMUCaps. Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
fed92f08db
commit
32803ba409
File diff suppressed because it is too large
Load Diff
@ -31,7 +31,7 @@
|
|||||||
# include "qemu_monitor.h"
|
# include "qemu_monitor.h"
|
||||||
|
|
||||||
/* Internal flags to keep track of qemu command line capabilities */
|
/* Internal flags to keep track of qemu command line capabilities */
|
||||||
enum qemuCapsFlags {
|
enum virQEMUCapsFlags {
|
||||||
QEMU_CAPS_KQEMU = 0, /* Whether KQEMU is compiled in */
|
QEMU_CAPS_KQEMU = 0, /* Whether KQEMU is compiled in */
|
||||||
QEMU_CAPS_VNC_COLON = 1, /* VNC takes or address + display */
|
QEMU_CAPS_VNC_COLON = 1, /* VNC takes or address + display */
|
||||||
QEMU_CAPS_NO_REBOOT = 2, /* Is the -no-reboot flag available */
|
QEMU_CAPS_NO_REBOOT = 2, /* Is the -no-reboot flag available */
|
||||||
@ -170,79 +170,81 @@ enum qemuCapsFlags {
|
|||||||
QEMU_CAPS_LAST, /* this must always be the last item */
|
QEMU_CAPS_LAST, /* this must always be the last item */
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _qemuCaps qemuCaps;
|
typedef struct _virQEMUCaps virQEMUCaps;
|
||||||
typedef qemuCaps *qemuCapsPtr;
|
typedef virQEMUCaps *virQEMUCapsPtr;
|
||||||
|
|
||||||
typedef struct _qemuCapsCache qemuCapsCache;
|
typedef struct _virQEMUCapsCache virQEMUCapsCache;
|
||||||
typedef qemuCapsCache *qemuCapsCachePtr;
|
typedef virQEMUCapsCache *virQEMUCapsCachePtr;
|
||||||
|
|
||||||
qemuCapsPtr qemuCapsNew(void);
|
virQEMUCapsPtr virQEMUCapsNew(void);
|
||||||
qemuCapsPtr qemuCapsNewCopy(qemuCapsPtr caps);
|
virQEMUCapsPtr virQEMUCapsNewCopy(virQEMUCapsPtr qemuCaps);
|
||||||
qemuCapsPtr qemuCapsNewForBinary(const char *binary,
|
virQEMUCapsPtr virQEMUCapsNewForBinary(const char *binary,
|
||||||
const char *libDir,
|
const char *libDir,
|
||||||
uid_t runUid,
|
uid_t runUid,
|
||||||
gid_t runGid);
|
gid_t runGid);
|
||||||
|
|
||||||
int qemuCapsProbeQMP(qemuCapsPtr caps,
|
int virQEMUCapsProbeQMP(virQEMUCapsPtr qemuCaps,
|
||||||
qemuMonitorPtr mon);
|
qemuMonitorPtr mon);
|
||||||
|
|
||||||
void qemuCapsSet(qemuCapsPtr caps,
|
void virQEMUCapsSet(virQEMUCapsPtr qemuCaps,
|
||||||
enum qemuCapsFlags flag) ATTRIBUTE_NONNULL(1);
|
enum virQEMUCapsFlags flag) ATTRIBUTE_NONNULL(1);
|
||||||
|
|
||||||
void qemuCapsSetList(qemuCapsPtr caps, ...) ATTRIBUTE_NONNULL(1);
|
void virQEMUCapsSetList(virQEMUCapsPtr qemuCaps, ...) ATTRIBUTE_NONNULL(1);
|
||||||
|
|
||||||
void qemuCapsClear(qemuCapsPtr caps,
|
void virQEMUCapsClear(virQEMUCapsPtr qemuCaps,
|
||||||
enum qemuCapsFlags flag) ATTRIBUTE_NONNULL(1);
|
enum virQEMUCapsFlags flag) ATTRIBUTE_NONNULL(1);
|
||||||
|
|
||||||
bool qemuCapsGet(qemuCapsPtr caps,
|
bool virQEMUCapsGet(virQEMUCapsPtr qemuCaps,
|
||||||
enum qemuCapsFlags flag);
|
enum virQEMUCapsFlags flag);
|
||||||
|
|
||||||
char *qemuCapsFlagsString(qemuCapsPtr caps);
|
char *virQEMUCapsFlagsString(virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
const char *qemuCapsGetBinary(qemuCapsPtr caps);
|
const char *virQEMUCapsGetBinary(virQEMUCapsPtr qemuCaps);
|
||||||
virArch qemuCapsGetArch(qemuCapsPtr caps);
|
virArch virQEMUCapsGetArch(virQEMUCapsPtr qemuCaps);
|
||||||
unsigned int qemuCapsGetVersion(qemuCapsPtr caps);
|
unsigned int virQEMUCapsGetVersion(virQEMUCapsPtr qemuCaps);
|
||||||
unsigned int qemuCapsGetKVMVersion(qemuCapsPtr caps);
|
unsigned int virQEMUCapsGetKVMVersion(virQEMUCapsPtr qemuCaps);
|
||||||
int qemuCapsAddCPUDefinition(qemuCapsPtr caps,
|
int virQEMUCapsAddCPUDefinition(virQEMUCapsPtr qemuCaps,
|
||||||
const char *name);
|
const char *name);
|
||||||
size_t qemuCapsGetCPUDefinitions(qemuCapsPtr caps,
|
size_t virQEMUCapsGetCPUDefinitions(virQEMUCapsPtr qemuCaps,
|
||||||
char ***names);
|
char ***names);
|
||||||
size_t qemuCapsGetMachineTypes(qemuCapsPtr caps,
|
size_t virQEMUCapsGetMachineTypes(virQEMUCapsPtr qemuCaps,
|
||||||
char ***names);
|
char ***names);
|
||||||
const char *qemuCapsGetCanonicalMachine(qemuCapsPtr caps,
|
const char *virQEMUCapsGetCanonicalMachine(virQEMUCapsPtr qemuCaps,
|
||||||
const char *name);
|
const char *name);
|
||||||
|
|
||||||
int qemuCapsGetMachineTypesCaps(qemuCapsPtr caps,
|
int virQEMUCapsGetMachineTypesCaps(virQEMUCapsPtr qemuCaps,
|
||||||
size_t *nmachines,
|
size_t *nmachines,
|
||||||
virCapsGuestMachinePtr **machines);
|
virCapsGuestMachinePtr **machines);
|
||||||
|
|
||||||
bool qemuCapsIsValid(qemuCapsPtr caps);
|
bool virQEMUCapsIsValid(virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
|
|
||||||
qemuCapsCachePtr qemuCapsCacheNew(const char *libDir,
|
virQEMUCapsCachePtr virQEMUCapsCacheNew(const char *libDir,
|
||||||
uid_t uid, gid_t gid);
|
uid_t uid, gid_t gid);
|
||||||
qemuCapsPtr qemuCapsCacheLookup(qemuCapsCachePtr cache, const char *binary);
|
virQEMUCapsPtr virQEMUCapsCacheLookup(virQEMUCapsCachePtr cache,
|
||||||
qemuCapsPtr qemuCapsCacheLookupCopy(qemuCapsCachePtr cache, const char *binary);
|
const char *binary);
|
||||||
void qemuCapsCacheFree(qemuCapsCachePtr cache);
|
virQEMUCapsPtr virQEMUCapsCacheLookupCopy(virQEMUCapsCachePtr cache,
|
||||||
|
const char *binary);
|
||||||
|
void virQEMUCapsCacheFree(virQEMUCapsCachePtr cache);
|
||||||
|
|
||||||
virCapsPtr qemuCapsInit(qemuCapsCachePtr cache);
|
virCapsPtr virQEMUCapsInit(virQEMUCapsCachePtr cache);
|
||||||
|
|
||||||
int qemuCapsGetDefaultVersion(virCapsPtr caps,
|
int virQEMUCapsGetDefaultVersion(virCapsPtr caps,
|
||||||
qemuCapsCachePtr capsCache,
|
virQEMUCapsCachePtr capsCache,
|
||||||
unsigned int *version);
|
unsigned int *version);
|
||||||
|
|
||||||
/* Only for use by test suite */
|
/* Only for use by test suite */
|
||||||
int qemuCapsParseHelpStr(const char *qemu,
|
int virQEMUCapsParseHelpStr(const char *qemu,
|
||||||
const char *str,
|
const char *str,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
unsigned int *version,
|
unsigned int *version,
|
||||||
unsigned int *is_kvm,
|
unsigned int *is_kvm,
|
||||||
unsigned int *kvm_version,
|
unsigned int *kvm_version,
|
||||||
bool check_yajl);
|
bool check_yajl);
|
||||||
/* Only for use by test suite */
|
/* Only for use by test suite */
|
||||||
int qemuCapsParseDeviceStr(qemuCapsPtr caps, const char *str);
|
int virQEMUCapsParseDeviceStr(virQEMUCapsPtr qemuCaps, const char *str);
|
||||||
|
|
||||||
VIR_ENUM_DECL(qemuCaps);
|
VIR_ENUM_DECL(virQEMUCaps);
|
||||||
|
|
||||||
bool qemuCapsUsedQMP(qemuCapsPtr caps);
|
bool virQEMUCapsUsedQMP(virQEMUCapsPtr qemuCaps);
|
||||||
#endif /* __QEMU_CAPABILITIES_H__*/
|
#endif /* __QEMU_CAPABILITIES_H__*/
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -54,7 +54,7 @@ virCommandPtr qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
virDomainDefPtr def,
|
virDomainDefPtr def,
|
||||||
virDomainChrSourceDefPtr monitor_chr,
|
virDomainChrSourceDefPtr monitor_chr,
|
||||||
bool monitor_json,
|
bool monitor_json,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
const char *migrateFrom,
|
const char *migrateFrom,
|
||||||
int migrateFd,
|
int migrateFd,
|
||||||
virDomainSnapshotObjPtr current_snapshot,
|
virDomainSnapshotObjPtr current_snapshot,
|
||||||
@ -64,14 +64,14 @@ virCommandPtr qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
/* Generate string for arch-specific '-device' parameter */
|
/* Generate string for arch-specific '-device' parameter */
|
||||||
char *
|
char *
|
||||||
qemuBuildChrDeviceStr (virDomainChrDefPtr serial,
|
qemuBuildChrDeviceStr (virDomainChrDefPtr serial,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
virArch arch,
|
virArch arch,
|
||||||
char *machine);
|
char *machine);
|
||||||
|
|
||||||
/* With vlan == -1, use netdev syntax, else old hostnet */
|
/* With vlan == -1, use netdev syntax, else old hostnet */
|
||||||
char * qemuBuildHostNetStr(virDomainNetDefPtr net,
|
char * qemuBuildHostNetStr(virDomainNetDefPtr net,
|
||||||
virQEMUDriverPtr driver,
|
virQEMUDriverPtr driver,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
char type_sep,
|
char type_sep,
|
||||||
int vlan,
|
int vlan,
|
||||||
const char *tapfd,
|
const char *tapfd,
|
||||||
@ -86,50 +86,50 @@ char * qemuBuildNicStr(virDomainNetDefPtr net,
|
|||||||
char * qemuBuildNicDevStr(virDomainNetDefPtr net,
|
char * qemuBuildNicDevStr(virDomainNetDefPtr net,
|
||||||
int vlan,
|
int vlan,
|
||||||
int bootindex,
|
int bootindex,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
char *qemuDeviceDriveHostAlias(virDomainDiskDefPtr disk,
|
char *qemuDeviceDriveHostAlias(virDomainDiskDefPtr disk,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
/* Both legacy & current support */
|
/* Both legacy & current support */
|
||||||
char *qemuBuildDriveStr(virConnectPtr conn,
|
char *qemuBuildDriveStr(virConnectPtr conn,
|
||||||
virDomainDiskDefPtr disk,
|
virDomainDiskDefPtr disk,
|
||||||
bool bootable,
|
bool bootable,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
char *qemuBuildFSStr(virDomainFSDefPtr fs,
|
char *qemuBuildFSStr(virDomainFSDefPtr fs,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
/* Current, best practice */
|
/* Current, best practice */
|
||||||
char * qemuBuildDriveDevStr(virDomainDefPtr def,
|
char * qemuBuildDriveDevStr(virDomainDefPtr def,
|
||||||
virDomainDiskDefPtr disk,
|
virDomainDiskDefPtr disk,
|
||||||
int bootindex,
|
int bootindex,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
char * qemuBuildFSDevStr(virDomainFSDefPtr fs,
|
char * qemuBuildFSDevStr(virDomainFSDefPtr fs,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
/* Current, best practice */
|
/* Current, best practice */
|
||||||
char * qemuBuildControllerDevStr(virDomainDefPtr domainDef,
|
char * qemuBuildControllerDevStr(virDomainDefPtr domainDef,
|
||||||
virDomainControllerDefPtr def,
|
virDomainControllerDefPtr def,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
int *nusbcontroller);
|
int *nusbcontroller);
|
||||||
|
|
||||||
char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev,
|
char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
char * qemuBuildMemballoonDevStr(virDomainMemballoonDefPtr dev,
|
char * qemuBuildMemballoonDevStr(virDomainMemballoonDefPtr dev,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev,
|
char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound,
|
char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
/* Legacy, pre device support */
|
/* Legacy, pre device support */
|
||||||
char * qemuBuildPCIHostdevPCIDevStr(virDomainHostdevDefPtr dev);
|
char * qemuBuildPCIHostdevPCIDevStr(virDomainHostdevDefPtr dev);
|
||||||
/* Current, best practice */
|
/* Current, best practice */
|
||||||
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev,
|
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev,
|
||||||
const char *configfd,
|
const char *configfd,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
int qemuOpenPCIConfig(virDomainHostdevDefPtr dev);
|
int qemuOpenPCIConfig(virDomainHostdevDefPtr dev);
|
||||||
|
|
||||||
@ -137,61 +137,61 @@ int qemuOpenPCIConfig(virDomainHostdevDefPtr dev);
|
|||||||
char * qemuBuildUSBHostdevUsbDevStr(virDomainHostdevDefPtr dev);
|
char * qemuBuildUSBHostdevUsbDevStr(virDomainHostdevDefPtr dev);
|
||||||
/* Current, best practice */
|
/* Current, best practice */
|
||||||
char * qemuBuildUSBHostdevDevStr(virDomainHostdevDefPtr dev,
|
char * qemuBuildUSBHostdevDevStr(virDomainHostdevDefPtr dev,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
char * qemuBuildHubDevStr(virDomainHubDefPtr dev, qemuCapsPtr caps);
|
char * qemuBuildHubDevStr(virDomainHubDefPtr dev, virQEMUCapsPtr qemuCaps);
|
||||||
char * qemuBuildRedirdevDevStr(virDomainDefPtr def,
|
char * qemuBuildRedirdevDevStr(virDomainDefPtr def,
|
||||||
virDomainRedirdevDefPtr dev,
|
virDomainRedirdevDefPtr dev,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
int qemuNetworkIfaceConnect(virDomainDefPtr def,
|
int qemuNetworkIfaceConnect(virDomainDefPtr def,
|
||||||
virConnectPtr conn,
|
virConnectPtr conn,
|
||||||
virQEMUDriverPtr driver,
|
virQEMUDriverPtr driver,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
qemuCapsPtr caps)
|
virQEMUCapsPtr qemuCaps)
|
||||||
ATTRIBUTE_NONNULL(2);
|
ATTRIBUTE_NONNULL(2);
|
||||||
|
|
||||||
int qemuPhysIfaceConnect(virDomainDefPtr def,
|
int qemuPhysIfaceConnect(virDomainDefPtr def,
|
||||||
virQEMUDriverPtr driver,
|
virQEMUDriverPtr driver,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
enum virNetDevVPortProfileOp vmop);
|
enum virNetDevVPortProfileOp vmop);
|
||||||
|
|
||||||
int qemuOpenVhostNet(virDomainDefPtr def,
|
int qemuOpenVhostNet(virDomainDefPtr def,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
int *vhostfd);
|
int *vhostfd);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* NB: def->name can be NULL upon return and the caller
|
* NB: def->name can be NULL upon return and the caller
|
||||||
* *must* decide how to fill in a name in this case
|
* *must* decide how to fill in a name in this case
|
||||||
*/
|
*/
|
||||||
virDomainDefPtr qemuParseCommandLine(virCapsPtr caps,
|
virDomainDefPtr qemuParseCommandLine(virCapsPtr qemuCaps,
|
||||||
const char **progenv,
|
const char **progenv,
|
||||||
const char **progargv,
|
const char **progargv,
|
||||||
char **pidfile,
|
char **pidfile,
|
||||||
virDomainChrSourceDefPtr *monConfig,
|
virDomainChrSourceDefPtr *monConfig,
|
||||||
bool *monJSON);
|
bool *monJSON);
|
||||||
virDomainDefPtr qemuParseCommandLineString(virCapsPtr caps,
|
virDomainDefPtr qemuParseCommandLineString(virCapsPtr qemuCaps,
|
||||||
const char *args,
|
const char *args,
|
||||||
char **pidfile,
|
char **pidfile,
|
||||||
virDomainChrSourceDefPtr *monConfig,
|
virDomainChrSourceDefPtr *monConfig,
|
||||||
bool *monJSON);
|
bool *monJSON);
|
||||||
virDomainDefPtr qemuParseCommandLinePid(virCapsPtr caps,
|
virDomainDefPtr qemuParseCommandLinePid(virCapsPtr qemuCaps,
|
||||||
pid_t pid,
|
pid_t pid,
|
||||||
char **pidfile,
|
char **pidfile,
|
||||||
virDomainChrSourceDefPtr *monConfig,
|
virDomainChrSourceDefPtr *monConfig,
|
||||||
bool *monJSON);
|
bool *monJSON);
|
||||||
|
|
||||||
int qemuDomainAssignAddresses(virDomainDefPtr def,
|
int qemuDomainAssignAddresses(virDomainDefPtr def,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
virDomainObjPtr obj)
|
virDomainObjPtr obj)
|
||||||
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
|
||||||
int qemuDomainAssignSpaprVIOAddresses(virDomainDefPtr def,
|
int qemuDomainAssignSpaprVIOAddresses(virDomainDefPtr def,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
|
|
||||||
int qemuDomainAssignPCIAddresses(virDomainDefPtr def,
|
int qemuDomainAssignPCIAddresses(virDomainDefPtr def,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
virDomainObjPtr obj);
|
virDomainObjPtr obj);
|
||||||
qemuDomainPCIAddressSetPtr qemuDomainPCIAddressSetCreate(virDomainDefPtr def);
|
qemuDomainPCIAddressSetPtr qemuDomainPCIAddressSetCreate(virDomainDefPtr def);
|
||||||
int qemuDomainPCIAddressReserveFunction(qemuDomainPCIAddressSetPtr addrs,
|
int qemuDomainPCIAddressReserveFunction(qemuDomainPCIAddressSetPtr addrs,
|
||||||
@ -212,15 +212,15 @@ int qemuDomainPCIAddressReleaseSlot(qemuDomainPCIAddressSetPtr addrs, int slot);
|
|||||||
|
|
||||||
void qemuDomainPCIAddressSetFree(qemuDomainPCIAddressSetPtr addrs);
|
void qemuDomainPCIAddressSetFree(qemuDomainPCIAddressSetPtr addrs);
|
||||||
int qemuAssignDevicePCISlots(virDomainDefPtr def,
|
int qemuAssignDevicePCISlots(virDomainDefPtr def,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
qemuDomainPCIAddressSetPtr addrs);
|
qemuDomainPCIAddressSetPtr addrs);
|
||||||
|
|
||||||
int qemuAssignDeviceAliases(virDomainDefPtr def, qemuCapsPtr caps);
|
int qemuAssignDeviceAliases(virDomainDefPtr def, virQEMUCapsPtr qemuCaps);
|
||||||
int qemuDomainNetVLAN(virDomainNetDefPtr def);
|
int qemuDomainNetVLAN(virDomainNetDefPtr def);
|
||||||
int qemuAssignDeviceNetAlias(virDomainDefPtr def, virDomainNetDefPtr net, int idx);
|
int qemuAssignDeviceNetAlias(virDomainDefPtr def, virDomainNetDefPtr net, int idx);
|
||||||
int qemuAssignDeviceDiskAlias(virDomainDefPtr vmdef,
|
int qemuAssignDeviceDiskAlias(virDomainDefPtr vmdef,
|
||||||
virDomainDiskDefPtr def,
|
virDomainDiskDefPtr def,
|
||||||
qemuCapsPtr caps);
|
virQEMUCapsPtr qemuCaps);
|
||||||
int qemuAssignDeviceHostdevAlias(virDomainDefPtr def, virDomainHostdevDefPtr hostdev, int idx);
|
int qemuAssignDeviceHostdevAlias(virDomainDefPtr def, virDomainHostdevDefPtr hostdev, int idx);
|
||||||
int qemuAssignDeviceControllerAlias(virDomainControllerDefPtr controller);
|
int qemuAssignDeviceControllerAlias(virDomainControllerDefPtr controller);
|
||||||
int qemuAssignDeviceRedirdevAlias(virDomainDefPtr def, virDomainRedirdevDefPtr redirdev, int idx);
|
int qemuAssignDeviceRedirdevAlias(virDomainDefPtr def, virDomainRedirdevDefPtr redirdev, int idx);
|
||||||
|
@ -187,7 +187,7 @@ struct _virQEMUDriver {
|
|||||||
virCapsPtr caps;
|
virCapsPtr caps;
|
||||||
|
|
||||||
/* Immutable pointer, self-locking APIs */
|
/* Immutable pointer, self-locking APIs */
|
||||||
qemuCapsCachePtr capsCache;
|
virQEMUCapsCachePtr qemuCapsCache;
|
||||||
|
|
||||||
/* Immutable pointer, self-locking APIs */
|
/* Immutable pointer, self-locking APIs */
|
||||||
virDomainEventStatePtr domainEventState;
|
virDomainEventStatePtr domainEventState;
|
||||||
|
@ -231,7 +231,7 @@ static void qemuDomainObjPrivateFree(void *data)
|
|||||||
{
|
{
|
||||||
qemuDomainObjPrivatePtr priv = data;
|
qemuDomainObjPrivatePtr priv = data;
|
||||||
|
|
||||||
virObjectUnref(priv->caps);
|
virObjectUnref(priv->qemuCaps);
|
||||||
|
|
||||||
qemuDomainPCIAddressSetFree(priv->pciaddrs);
|
qemuDomainPCIAddressSetFree(priv->pciaddrs);
|
||||||
virDomainChrSourceDefFree(priv->monConfig);
|
virDomainChrSourceDefFree(priv->monConfig);
|
||||||
@ -291,13 +291,13 @@ static int qemuDomainObjPrivateXMLFormat(virBufferPtr buf, void *data)
|
|||||||
virBufferAddLit(buf, " </vcpus>\n");
|
virBufferAddLit(buf, " </vcpus>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (priv->caps) {
|
if (priv->qemuCaps) {
|
||||||
int i;
|
int i;
|
||||||
virBufferAddLit(buf, " <qemuCaps>\n");
|
virBufferAddLit(buf, " <qemuCaps>\n");
|
||||||
for (i = 0 ; i < QEMU_CAPS_LAST ; i++) {
|
for (i = 0 ; i < QEMU_CAPS_LAST ; i++) {
|
||||||
if (qemuCapsGet(priv->caps, i)) {
|
if (virQEMUCapsGet(priv->qemuCaps, i)) {
|
||||||
virBufferAsprintf(buf, " <flag name='%s'/>\n",
|
virBufferAsprintf(buf, " <flag name='%s'/>\n",
|
||||||
qemuCapsTypeToString(i));
|
virQEMUCapsTypeToString(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
virBufferAddLit(buf, " </qemuCaps>\n");
|
virBufferAddLit(buf, " </qemuCaps>\n");
|
||||||
@ -336,7 +336,7 @@ static int qemuDomainObjPrivateXMLParse(xmlXPathContextPtr ctxt, void *data)
|
|||||||
char *tmp;
|
char *tmp;
|
||||||
int n, i;
|
int n, i;
|
||||||
xmlNodePtr *nodes = NULL;
|
xmlNodePtr *nodes = NULL;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
|
|
||||||
if (VIR_ALLOC(priv->monConfig) < 0) {
|
if (VIR_ALLOC(priv->monConfig) < 0) {
|
||||||
virReportOOMError();
|
virReportOOMError();
|
||||||
@ -408,13 +408,13 @@ static int qemuDomainObjPrivateXMLParse(xmlXPathContextPtr ctxt, void *data)
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
if (n > 0) {
|
if (n > 0) {
|
||||||
if (!(caps = qemuCapsNew()))
|
if (!(qemuCaps = virQEMUCapsNew()))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
for (i = 0 ; i < n ; i++) {
|
for (i = 0 ; i < n ; i++) {
|
||||||
char *str = virXMLPropString(nodes[i], "name");
|
char *str = virXMLPropString(nodes[i], "name");
|
||||||
if (str) {
|
if (str) {
|
||||||
int flag = qemuCapsTypeFromString(str);
|
int flag = virQEMUCapsTypeFromString(str);
|
||||||
if (flag < 0) {
|
if (flag < 0) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
_("Unknown qemu capabilities flag %s"), str);
|
_("Unknown qemu capabilities flag %s"), str);
|
||||||
@ -422,11 +422,11 @@ static int qemuDomainObjPrivateXMLParse(xmlXPathContextPtr ctxt, void *data)
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
VIR_FREE(str);
|
VIR_FREE(str);
|
||||||
qemuCapsSet(caps, flag);
|
virQEMUCapsSet(qemuCaps, flag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
priv->caps = caps;
|
priv->qemuCaps = qemuCaps;
|
||||||
}
|
}
|
||||||
VIR_FREE(nodes);
|
VIR_FREE(nodes);
|
||||||
|
|
||||||
@ -477,7 +477,7 @@ error:
|
|||||||
virDomainChrSourceDefFree(priv->monConfig);
|
virDomainChrSourceDefFree(priv->monConfig);
|
||||||
priv->monConfig = NULL;
|
priv->monConfig = NULL;
|
||||||
VIR_FREE(nodes);
|
VIR_FREE(nodes);
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,7 +145,7 @@ struct _qemuDomainObjPrivate {
|
|||||||
qemuDomainPCIAddressSetPtr pciaddrs;
|
qemuDomainPCIAddressSetPtr pciaddrs;
|
||||||
int persistentAddrs;
|
int persistentAddrs;
|
||||||
|
|
||||||
qemuCapsPtr caps;
|
virQEMUCapsPtr qemuCaps;
|
||||||
char *lockState;
|
char *lockState;
|
||||||
|
|
||||||
bool fakeReboot;
|
bool fakeReboot;
|
||||||
|
@ -427,7 +427,7 @@ qemuCreateCapabilities(virQEMUDriverPtr driver)
|
|||||||
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
|
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
|
||||||
|
|
||||||
/* Basic host arch / guest machine capabilities */
|
/* Basic host arch / guest machine capabilities */
|
||||||
if (!(caps = qemuCapsInit(driver->capsCache))) {
|
if (!(caps = virQEMUCapsInit(driver->qemuCapsCache))) {
|
||||||
virReportOOMError();
|
virReportOOMError();
|
||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -816,10 +816,10 @@ qemuStartup(bool privileged,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
qemu_driver->capsCache = qemuCapsCacheNew(cfg->libDir,
|
qemu_driver->qemuCapsCache = virQEMUCapsCacheNew(cfg->libDir,
|
||||||
cfg->user,
|
cfg->user,
|
||||||
cfg->group);
|
cfg->group);
|
||||||
if (!qemu_driver->capsCache)
|
if (!qemu_driver->qemuCapsCache)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if ((qemu_driver->caps = qemuCreateCapabilities(qemu_driver)) == NULL)
|
if ((qemu_driver->caps = qemuCreateCapabilities(qemu_driver)) == NULL)
|
||||||
@ -1055,7 +1055,7 @@ qemuShutdown(void) {
|
|||||||
virObjectUnref(qemu_driver->activeUsbHostdevs);
|
virObjectUnref(qemu_driver->activeUsbHostdevs);
|
||||||
virHashFree(qemu_driver->sharedDisks);
|
virHashFree(qemu_driver->sharedDisks);
|
||||||
virObjectUnref(qemu_driver->caps);
|
virObjectUnref(qemu_driver->caps);
|
||||||
qemuCapsCacheFree(qemu_driver->capsCache);
|
virQEMUCapsCacheFree(qemu_driver->qemuCapsCache);
|
||||||
|
|
||||||
virObjectUnref(qemu_driver->domains);
|
virObjectUnref(qemu_driver->domains);
|
||||||
virObjectUnref(qemu_driver->remotePorts);
|
virObjectUnref(qemu_driver->remotePorts);
|
||||||
@ -1505,8 +1505,8 @@ static int qemuGetVersion(virConnectPtr conn, unsigned long *version) {
|
|||||||
unsigned int qemuVersion;
|
unsigned int qemuVersion;
|
||||||
|
|
||||||
qemuDriverLock(driver);
|
qemuDriverLock(driver);
|
||||||
if (qemuCapsGetDefaultVersion(driver->caps,
|
if (virQEMUCapsGetDefaultVersion(driver->caps,
|
||||||
driver->capsCache,
|
driver->qemuCapsCache,
|
||||||
&qemuVersion) < 0)
|
&qemuVersion) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -1542,11 +1542,11 @@ static int qemuNumDomains(virConnectPtr conn) {
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuCanonicalizeMachine(virDomainDefPtr def, qemuCapsPtr caps)
|
qemuCanonicalizeMachine(virDomainDefPtr def, virQEMUCapsPtr qemuCaps)
|
||||||
{
|
{
|
||||||
const char *canon;
|
const char *canon;
|
||||||
|
|
||||||
if (!(canon = qemuCapsGetCanonicalMachine(caps, def->os.machine)))
|
if (!(canon = virQEMUCapsGetCanonicalMachine(qemuCaps, def->os.machine)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (STRNEQ(canon, def->os.machine)) {
|
if (STRNEQ(canon, def->os.machine)) {
|
||||||
@ -1572,7 +1572,7 @@ static virDomainPtr qemuDomainCreate(virConnectPtr conn, const char *xml,
|
|||||||
virDomainEventPtr event = NULL;
|
virDomainEventPtr event = NULL;
|
||||||
virDomainEventPtr event2 = NULL;
|
virDomainEventPtr event2 = NULL;
|
||||||
unsigned int start_flags = VIR_QEMU_PROCESS_START_COLD;
|
unsigned int start_flags = VIR_QEMU_PROCESS_START_COLD;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_START_PAUSED |
|
virCheckFlags(VIR_DOMAIN_START_PAUSED |
|
||||||
VIR_DOMAIN_START_AUTODESTROY, NULL);
|
VIR_DOMAIN_START_AUTODESTROY, NULL);
|
||||||
@ -1591,13 +1591,13 @@ static virDomainPtr qemuDomainCreate(virConnectPtr conn, const char *xml,
|
|||||||
if (virSecurityManagerVerify(driver->securityManager, def) < 0)
|
if (virSecurityManagerVerify(driver->securityManager, def) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(caps = qemuCapsCacheLookup(driver->capsCache, def->emulator)))
|
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCanonicalizeMachine(def, caps) < 0)
|
if (qemuCanonicalizeMachine(def, qemuCaps) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuDomainAssignAddresses(def, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(def, qemuCaps, NULL) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(vm = virDomainObjListAdd(driver->domains,
|
if (!(vm = virDomainObjListAdd(driver->domains,
|
||||||
@ -1653,7 +1653,7 @@ cleanup:
|
|||||||
if (event2)
|
if (event2)
|
||||||
qemuDomainEventQueue(driver, event2);
|
qemuDomainEventQueue(driver, event2);
|
||||||
}
|
}
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
qemuDriverUnlock(driver);
|
qemuDriverUnlock(driver);
|
||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
@ -1934,8 +1934,8 @@ qemuDomainReboot(virDomainPtr dom, unsigned int flags)
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
#if WITH_YAJL
|
#if WITH_YAJL
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MONITOR_JSON)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MONITOR_JSON)) {
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_NO_SHUTDOWN)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NO_SHUTDOWN)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("Reboot is not supported with this QEMU binary"));
|
_("Reboot is not supported with this QEMU binary"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -2412,7 +2412,7 @@ static int qemuDomainGetInfo(virDomainPtr dom,
|
|||||||
if ((vm->def->memballoon != NULL) &&
|
if ((vm->def->memballoon != NULL) &&
|
||||||
(vm->def->memballoon->model == VIR_DOMAIN_MEMBALLOON_MODEL_NONE)) {
|
(vm->def->memballoon->model == VIR_DOMAIN_MEMBALLOON_MODEL_NONE)) {
|
||||||
info->memory = vm->def->mem.max_balloon;
|
info->memory = vm->def->mem.max_balloon;
|
||||||
} else if (qemuCapsGet(priv->caps, QEMU_CAPS_BALLOON_EVENT)) {
|
} else if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BALLOON_EVENT)) {
|
||||||
info->memory = vm->def->mem.cur_balloon;
|
info->memory = vm->def->mem.cur_balloon;
|
||||||
} else if (qemuDomainJobAllowed(priv, QEMU_JOB_QUERY)) {
|
} else if (qemuDomainJobAllowed(priv, QEMU_JOB_QUERY)) {
|
||||||
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_QUERY) < 0)
|
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_QUERY) < 0)
|
||||||
@ -3206,7 +3206,7 @@ static int qemuDumpToFd(virQEMUDriverPtr driver, virDomainObjPtr vm,
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DUMP_GUEST_MEMORY)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DUMP_GUEST_MEMORY)) {
|
||||||
virReportError(VIR_ERR_NO_SUPPORT, "%s",
|
virReportError(VIR_ERR_NO_SUPPORT, "%s",
|
||||||
_("dump-guest-memory is not supported"));
|
_("dump-guest-memory is not supported"));
|
||||||
return -1;
|
return -1;
|
||||||
@ -5216,7 +5216,7 @@ static char *qemuDomainGetXMLDesc(virDomainPtr dom,
|
|||||||
/* Refresh current memory based on balloon info if supported */
|
/* Refresh current memory based on balloon info if supported */
|
||||||
if ((vm->def->memballoon != NULL) &&
|
if ((vm->def->memballoon != NULL) &&
|
||||||
(vm->def->memballoon->model != VIR_DOMAIN_MEMBALLOON_MODEL_NONE) &&
|
(vm->def->memballoon->model != VIR_DOMAIN_MEMBALLOON_MODEL_NONE) &&
|
||||||
!qemuCapsGet(priv->caps, QEMU_CAPS_BALLOON_EVENT) &&
|
!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BALLOON_EVENT) &&
|
||||||
(virDomainObjIsActive(vm))) {
|
(virDomainObjIsActive(vm))) {
|
||||||
/* Don't delay if someone's using the monitor, just use
|
/* Don't delay if someone's using the monitor, just use
|
||||||
* existing most recent data instead */
|
* existing most recent data instead */
|
||||||
@ -5305,7 +5305,7 @@ static char *qemuDomainXMLToNative(virConnectPtr conn,
|
|||||||
virQEMUDriverPtr driver = conn->privateData;
|
virQEMUDriverPtr driver = conn->privateData;
|
||||||
virDomainDefPtr def = NULL;
|
virDomainDefPtr def = NULL;
|
||||||
virDomainChrSourceDef monConfig;
|
virDomainChrSourceDef monConfig;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
bool monitor_json = false;
|
bool monitor_json = false;
|
||||||
virCommandPtr cmd = NULL;
|
virCommandPtr cmd = NULL;
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
@ -5328,7 +5328,7 @@ static char *qemuDomainXMLToNative(virConnectPtr conn,
|
|||||||
if (!def)
|
if (!def)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(caps = qemuCapsCacheLookup(driver->capsCache, def->emulator)))
|
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
/* Since we're just exporting args, we can't do bridge/network/direct
|
/* Since we're just exporting args, we can't do bridge/network/direct
|
||||||
@ -5403,16 +5403,16 @@ static char *qemuDomainXMLToNative(virConnectPtr conn,
|
|||||||
net->model = model;
|
net->model = model;
|
||||||
}
|
}
|
||||||
|
|
||||||
monitor_json = qemuCapsGet(caps, QEMU_CAPS_MONITOR_JSON);
|
monitor_json = virQEMUCapsGet(qemuCaps, QEMU_CAPS_MONITOR_JSON);
|
||||||
|
|
||||||
if (qemuProcessPrepareMonitorChr(cfg, &monConfig, def->name) < 0)
|
if (qemuProcessPrepareMonitorChr(cfg, &monConfig, def->name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuAssignDeviceAliases(def, caps) < 0)
|
if (qemuAssignDeviceAliases(def, qemuCaps) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(cmd = qemuBuildCommandLine(conn, driver, def,
|
if (!(cmd = qemuBuildCommandLine(conn, driver, def,
|
||||||
&monConfig, monitor_json, caps,
|
&monConfig, monitor_json, qemuCaps,
|
||||||
NULL, -1, NULL, VIR_NETDEV_VPORT_PROFILE_OP_NO_OP)))
|
NULL, -1, NULL, VIR_NETDEV_VPORT_PROFILE_OP_NO_OP)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -5421,7 +5421,7 @@ static char *qemuDomainXMLToNative(virConnectPtr conn,
|
|||||||
cleanup:
|
cleanup:
|
||||||
qemuDriverUnlock(driver);
|
qemuDriverUnlock(driver);
|
||||||
|
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
virCommandFree(cmd);
|
virCommandFree(cmd);
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
@ -5590,7 +5590,7 @@ static virDomainPtr qemuDomainDefine(virConnectPtr conn, const char *xml) {
|
|||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
virDomainPtr dom = NULL;
|
virDomainPtr dom = NULL;
|
||||||
virDomainEventPtr event = NULL;
|
virDomainEventPtr event = NULL;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
virQEMUDriverConfigPtr cfg;
|
virQEMUDriverConfigPtr cfg;
|
||||||
|
|
||||||
qemuDriverLock(driver);
|
qemuDriverLock(driver);
|
||||||
@ -5603,13 +5603,13 @@ static virDomainPtr qemuDomainDefine(virConnectPtr conn, const char *xml) {
|
|||||||
if (virSecurityManagerVerify(driver->securityManager, def) < 0)
|
if (virSecurityManagerVerify(driver->securityManager, def) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(caps = qemuCapsCacheLookup(driver->capsCache, def->emulator)))
|
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCanonicalizeMachine(def, caps) < 0)
|
if (qemuCanonicalizeMachine(def, qemuCaps) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuDomainAssignAddresses(def, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(def, qemuCaps, NULL) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(vm = virDomainObjListAdd(driver->domains,
|
if (!(vm = virDomainObjListAdd(driver->domains,
|
||||||
@ -5665,7 +5665,7 @@ cleanup:
|
|||||||
virObjectUnlock(vm);
|
virObjectUnlock(vm);
|
||||||
if (event)
|
if (event)
|
||||||
qemuDomainEventQueue(driver, event);
|
qemuDomainEventQueue(driver, event);
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
qemuDriverUnlock(driver);
|
qemuDriverUnlock(driver);
|
||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
return dom;
|
return dom;
|
||||||
@ -6119,7 +6119,7 @@ qemuDomainUpdateDeviceLive(virDomainObjPtr vm,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuDomainAttachDeviceConfig(qemuCapsPtr caps,
|
qemuDomainAttachDeviceConfig(virQEMUCapsPtr qemuCaps,
|
||||||
virDomainDefPtr vmdef,
|
virDomainDefPtr vmdef,
|
||||||
virDomainDeviceDefPtr dev)
|
virDomainDeviceDefPtr dev)
|
||||||
{
|
{
|
||||||
@ -6146,7 +6146,7 @@ qemuDomainAttachDeviceConfig(qemuCapsPtr caps,
|
|||||||
if (disk->bus != VIR_DOMAIN_DISK_BUS_VIRTIO)
|
if (disk->bus != VIR_DOMAIN_DISK_BUS_VIRTIO)
|
||||||
if (virDomainDefAddImplicitControllers(vmdef) < 0)
|
if (virDomainDefAddImplicitControllers(vmdef) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
if (qemuDomainAssignAddresses(vmdef, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(vmdef, qemuCaps, NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -6157,7 +6157,7 @@ qemuDomainAttachDeviceConfig(qemuCapsPtr caps,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
dev->data.net = NULL;
|
dev->data.net = NULL;
|
||||||
if (qemuDomainAssignAddresses(vmdef, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(vmdef, qemuCaps, NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -6173,7 +6173,7 @@ qemuDomainAttachDeviceConfig(qemuCapsPtr caps,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
dev->data.hostdev = NULL;
|
dev->data.hostdev = NULL;
|
||||||
if (qemuDomainAssignAddresses(vmdef, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(vmdef, qemuCaps, NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -6205,7 +6205,7 @@ qemuDomainAttachDeviceConfig(qemuCapsPtr caps,
|
|||||||
return -1;
|
return -1;
|
||||||
dev->data.controller = NULL;
|
dev->data.controller = NULL;
|
||||||
|
|
||||||
if (qemuDomainAssignAddresses(vmdef, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(vmdef, qemuCaps, NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -6303,7 +6303,7 @@ qemuDomainDetachDeviceConfig(virDomainDefPtr vmdef,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuDomainUpdateDeviceConfig(qemuCapsPtr caps,
|
qemuDomainUpdateDeviceConfig(virQEMUCapsPtr qemuCaps,
|
||||||
virDomainDefPtr vmdef,
|
virDomainDefPtr vmdef,
|
||||||
virDomainDeviceDefPtr dev)
|
virDomainDeviceDefPtr dev)
|
||||||
{
|
{
|
||||||
@ -6369,7 +6369,7 @@ qemuDomainUpdateDeviceConfig(qemuCapsPtr caps,
|
|||||||
vmdef->nets[pos] = net;
|
vmdef->nets[pos] = net;
|
||||||
dev->data.net = NULL;
|
dev->data.net = NULL;
|
||||||
|
|
||||||
if (qemuDomainAssignAddresses(vmdef, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(vmdef, qemuCaps, NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -6400,7 +6400,7 @@ qemuDomainModifyDeviceFlags(virDomainPtr dom, const char *xml,
|
|||||||
bool force = (flags & VIR_DOMAIN_DEVICE_MODIFY_FORCE) != 0;
|
bool force = (flags & VIR_DOMAIN_DEVICE_MODIFY_FORCE) != 0;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
unsigned int affect;
|
unsigned int affect;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv;
|
||||||
virQEMUDriverConfigPtr cfg = NULL;
|
virQEMUDriverConfigPtr cfg = NULL;
|
||||||
|
|
||||||
@ -6464,9 +6464,9 @@ qemuDomainModifyDeviceFlags(virDomainPtr dom, const char *xml,
|
|||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (priv->caps)
|
if (priv->qemuCaps)
|
||||||
caps = virObjectRef(priv->caps);
|
qemuCaps = virObjectRef(priv->qemuCaps);
|
||||||
else if (!(caps = qemuCapsCacheLookup(driver->capsCache, vm->def->emulator)))
|
else if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, vm->def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
|
if (flags & VIR_DOMAIN_AFFECT_CONFIG) {
|
||||||
@ -6479,13 +6479,13 @@ qemuDomainModifyDeviceFlags(virDomainPtr dom, const char *xml,
|
|||||||
goto endjob;
|
goto endjob;
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case QEMU_DEVICE_ATTACH:
|
case QEMU_DEVICE_ATTACH:
|
||||||
ret = qemuDomainAttachDeviceConfig(caps, vmdef, dev);
|
ret = qemuDomainAttachDeviceConfig(qemuCaps, vmdef, dev);
|
||||||
break;
|
break;
|
||||||
case QEMU_DEVICE_DETACH:
|
case QEMU_DEVICE_DETACH:
|
||||||
ret = qemuDomainDetachDeviceConfig(vmdef, dev);
|
ret = qemuDomainDetachDeviceConfig(vmdef, dev);
|
||||||
break;
|
break;
|
||||||
case QEMU_DEVICE_UPDATE:
|
case QEMU_DEVICE_UPDATE:
|
||||||
ret = qemuDomainUpdateDeviceConfig(caps, vmdef, dev);
|
ret = qemuDomainUpdateDeviceConfig(qemuCaps, vmdef, dev);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
@ -6545,7 +6545,7 @@ endjob:
|
|||||||
vm = NULL;
|
vm = NULL;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
virDomainDefFree(vmdef);
|
virDomainDefFree(vmdef);
|
||||||
if (dev != dev_copy)
|
if (dev != dev_copy)
|
||||||
virDomainDeviceDefFree(dev_copy);
|
virDomainDeviceDefFree(dev_copy);
|
||||||
@ -10733,7 +10733,7 @@ qemuDomainSnapshotPrepare(virDomainObjPtr vm, virDomainSnapshotDefPtr def,
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
|
|
||||||
if (def->state == VIR_DOMAIN_DISK_SNAPSHOT &&
|
if (def->state == VIR_DOMAIN_DISK_SNAPSHOT &&
|
||||||
reuse && !qemuCapsGet(priv->caps, QEMU_CAPS_TRANSACTION)) {
|
reuse && !virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_TRANSACTION)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("reuse is not supported with this QEMU binary"));
|
_("reuse is not supported with this QEMU binary"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -10849,7 +10849,7 @@ qemuDomainSnapshotPrepare(virDomainObjPtr vm, virDomainSnapshotDefPtr def,
|
|||||||
|
|
||||||
if (def->state != VIR_DOMAIN_DISK_SNAPSHOT && active) {
|
if (def->state != VIR_DOMAIN_DISK_SNAPSHOT && active) {
|
||||||
if (external == 1 ||
|
if (external == 1 ||
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_TRANSACTION)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_TRANSACTION)) {
|
||||||
*flags |= VIR_DOMAIN_SNAPSHOT_CREATE_ATOMIC;
|
*flags |= VIR_DOMAIN_SNAPSHOT_CREATE_ATOMIC;
|
||||||
} else if (atomic && external > 1) {
|
} else if (atomic && external > 1) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
@ -11035,12 +11035,12 @@ qemuDomainSnapshotCreateDiskActive(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
/* 'cgroup' is still NULL if cgroups are disabled. */
|
/* 'cgroup' is still NULL if cgroups are disabled. */
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_TRANSACTION)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_TRANSACTION)) {
|
||||||
if (!(actions = virJSONValueNewArray())) {
|
if (!(actions = virJSONValueNewArray())) {
|
||||||
virReportOOMError();
|
virReportOOMError();
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
} else if (!qemuCapsGet(priv->caps, QEMU_CAPS_DISK_SNAPSHOT)) {
|
} else if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DISK_SNAPSHOT)) {
|
||||||
virReportError(VIR_ERR_OPERATION_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_OPERATION_UNSUPPORTED, "%s",
|
||||||
_("live disk snapshot not supported with this "
|
_("live disk snapshot not supported with this "
|
||||||
"QEMU binary"));
|
"QEMU binary"));
|
||||||
@ -11112,7 +11112,7 @@ qemuDomainSnapshotCreateDiskActive(virQEMUDriverPtr driver,
|
|||||||
cleanup:
|
cleanup:
|
||||||
virCgroupFree(&cgroup);
|
virCgroupFree(&cgroup);
|
||||||
|
|
||||||
if (ret == 0 || !qemuCapsGet(priv->caps, QEMU_CAPS_TRANSACTION)) {
|
if (ret == 0 || !virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_TRANSACTION)) {
|
||||||
if (virDomainSaveStatus(driver->caps, cfg->stateDir, vm) < 0 ||
|
if (virDomainSaveStatus(driver->caps, cfg->stateDir, vm) < 0 ||
|
||||||
(persist && virDomainSaveConfig(cfg->configDir, vm->newDef) < 0))
|
(persist && virDomainSaveConfig(cfg->configDir, vm->newDef) < 0))
|
||||||
ret = -1;
|
ret = -1;
|
||||||
@ -11138,7 +11138,7 @@ qemuDomainSnapshotCreateActiveExternal(virConnectPtr conn,
|
|||||||
bool memory = snap->def->memory == VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL;
|
bool memory = snap->def->memory == VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL;
|
||||||
bool memory_unlink = false;
|
bool memory_unlink = false;
|
||||||
bool atomic = !!(flags & VIR_DOMAIN_SNAPSHOT_CREATE_ATOMIC);
|
bool atomic = !!(flags & VIR_DOMAIN_SNAPSHOT_CREATE_ATOMIC);
|
||||||
bool transaction = qemuCapsGet(priv->caps, QEMU_CAPS_TRANSACTION);
|
bool transaction = virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_TRANSACTION);
|
||||||
int thaw = 0; /* 1 if freeze succeeded, -1 if freeze failed */
|
int thaw = 0; /* 1 if freeze succeeded, -1 if freeze failed */
|
||||||
bool pmsuspended = false;
|
bool pmsuspended = false;
|
||||||
|
|
||||||
@ -12576,7 +12576,7 @@ static virDomainPtr qemuDomainAttach(virConnectPtr conn,
|
|||||||
bool monJSON = false;
|
bool monJSON = false;
|
||||||
pid_t pid = pid_value;
|
pid_t pid = pid_value;
|
||||||
char *pidfile = NULL;
|
char *pidfile = NULL;
|
||||||
qemuCapsPtr caps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
@ -12606,13 +12606,13 @@ static virDomainPtr qemuDomainAttach(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(caps = qemuCapsCacheLookup(driver->capsCache, def->emulator)))
|
if (!(qemuCaps = virQEMUCapsCacheLookup(driver->qemuCapsCache, def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCanonicalizeMachine(def, caps) < 0)
|
if (qemuCanonicalizeMachine(def, qemuCaps) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuDomainAssignAddresses(def, caps, NULL) < 0)
|
if (qemuDomainAssignAddresses(def, qemuCaps, NULL) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(vm = virDomainObjListAdd(driver->domains,
|
if (!(vm = virDomainObjListAdd(driver->domains,
|
||||||
@ -12647,7 +12647,7 @@ endjob:
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
virObjectUnref(caps);
|
virObjectUnref(qemuCaps);
|
||||||
virDomainChrSourceDefFree(monConfig);
|
virDomainChrSourceDefFree(monConfig);
|
||||||
if (vm)
|
if (vm)
|
||||||
virObjectUnlock(vm);
|
virObjectUnlock(vm);
|
||||||
@ -13034,9 +13034,9 @@ qemuDomainBlockJobImpl(virDomainPtr dom, const char *path, const char *base,
|
|||||||
}
|
}
|
||||||
|
|
||||||
priv = vm->privateData;
|
priv = vm->privateData;
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_BLOCKJOB_ASYNC)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCKJOB_ASYNC)) {
|
||||||
async = true;
|
async = true;
|
||||||
} else if (!qemuCapsGet(priv->caps, QEMU_CAPS_BLOCKJOB_SYNC)) {
|
} else if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCKJOB_SYNC)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("block jobs not supported with this QEMU binary"));
|
_("block jobs not supported with this QEMU binary"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -13251,8 +13251,8 @@ qemuDomainBlockCopy(virDomainPtr dom, const char *path,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(qemuCapsGet(priv->caps, QEMU_CAPS_DRIVE_MIRROR) &&
|
if (!(virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_MIRROR) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_BLOCKJOB_ASYNC))) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCKJOB_ASYNC))) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("block copy is not supported with this QEMU binary"));
|
_("block copy is not supported with this QEMU binary"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -13449,7 +13449,7 @@ qemuDomainBlockCommit(virDomainPtr dom, const char *path, const char *base,
|
|||||||
"%s", _("domain is not running"));
|
"%s", _("domain is not running"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_BLOCK_COMMIT)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_BLOCK_COMMIT)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("online commit not supported with this QEMU binary"));
|
_("online commit not supported with this QEMU binary"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
@ -13684,7 +13684,7 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
priv = vm->privateData;
|
priv = vm->privateData;
|
||||||
cfg = virQEMUDriverGetConfig(driver);
|
cfg = virQEMUDriverGetConfig(driver);
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DRIVE_IOTUNE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_IOTUNE)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("block I/O throttling not supported with this "
|
_("block I/O throttling not supported with this "
|
||||||
"QEMU binary"));
|
"QEMU binary"));
|
||||||
@ -14488,7 +14488,7 @@ qemuDomainPMSuspendForDuration(virDomainPtr dom,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_WAKEUP) &&
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_WAKEUP) &&
|
||||||
(target == VIR_NODE_SUSPEND_TARGET_MEM ||
|
(target == VIR_NODE_SUSPEND_TARGET_MEM ||
|
||||||
target == VIR_NODE_SUSPEND_TARGET_HYBRID)) {
|
target == VIR_NODE_SUSPEND_TARGET_HYBRID)) {
|
||||||
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_ARGUMENT_UNSUPPORTED, "%s",
|
||||||
@ -14575,7 +14575,7 @@ qemuDomainPMWakeup(virDomainPtr dom,
|
|||||||
|
|
||||||
priv = vm->privateData;
|
priv = vm->privateData;
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_WAKEUP)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_WAKEUP)) {
|
||||||
virReportError(VIR_ERR_OPERATION_INVALID, "%s",
|
virReportError(VIR_ERR_OPERATION_INVALID, "%s",
|
||||||
_("Unable to wake up domain due to "
|
_("Unable to wake up domain due to "
|
||||||
"missing system_wakeup monitor command"));
|
"missing system_wakeup monitor command"));
|
||||||
|
@ -104,7 +104,7 @@ int qemuDomainChangeEjectableMedia(virQEMUDriverPtr driver,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(driveAlias = qemuDeviceDriveHostAlias(origdisk, priv->caps)))
|
if (!(driveAlias = qemuDeviceDriveHostAlias(origdisk, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
@ -257,17 +257,17 @@ int qemuDomainAttachPciDiskDevice(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &disk->info) < 0)
|
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &disk->info) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
releaseaddr = true;
|
releaseaddr = true;
|
||||||
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->caps) < 0)
|
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->qemuCaps) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->caps)))
|
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (!(devstr = qemuBuildDriveDevStr(NULL, disk, 0, priv->caps)))
|
if (!(devstr = qemuBuildDriveDevStr(NULL, disk, 0, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,7 +277,7 @@ int qemuDomainAttachPciDiskDevice(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
@ -321,7 +321,7 @@ cleanup:
|
|||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
(disk->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
(disk->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
||||||
releaseaddr &&
|
releaseaddr &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
@ -356,7 +356,7 @@ int qemuDomainAttachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &controller->info) < 0)
|
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &controller->info) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
releaseaddr = true;
|
releaseaddr = true;
|
||||||
@ -365,13 +365,13 @@ int qemuDomainAttachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
|
|
||||||
if (controller->type == VIR_DOMAIN_CONTROLLER_TYPE_USB &&
|
if (controller->type == VIR_DOMAIN_CONTROLLER_TYPE_USB &&
|
||||||
controller->model == -1 &&
|
controller->model == -1 &&
|
||||||
!qemuCapsGet(priv->caps, QEMU_CAPS_PIIX3_USB_UHCI)) {
|
!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_PIIX3_USB_UHCI)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("USB controller hotplug unsupported in this QEMU binary"));
|
_("USB controller hotplug unsupported in this QEMU binary"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(devstr = qemuBuildControllerDevStr(vm->def, controller, priv->caps, NULL))) {
|
if (!(devstr = qemuBuildControllerDevStr(vm->def, controller, priv->qemuCaps, NULL))) {
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -382,7 +382,7 @@ int qemuDomainAttachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
} else {
|
} else {
|
||||||
ret = qemuMonitorAttachPCIDiskController(priv->mon,
|
ret = qemuMonitorAttachPCIDiskController(priv->mon,
|
||||||
@ -398,7 +398,7 @@ int qemuDomainAttachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if ((ret != 0) &&
|
if ((ret != 0) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
(controller->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
(controller->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
||||||
releaseaddr &&
|
releaseaddr &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
@ -497,14 +497,14 @@ int qemuDomainAttachSCSIDisk(virConnectPtr conn,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->caps) < 0)
|
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->qemuCaps) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
if (!(devstr = qemuBuildDriveDevStr(vm->def, disk, 0, priv->caps)))
|
if (!(devstr = qemuBuildDriveDevStr(vm->def, disk, 0, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->caps)))
|
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
for (i = 0 ; i <= disk->info.addr.drive.controller ; i++) {
|
for (i = 0 ; i <= disk->info.addr.drive.controller ; i++) {
|
||||||
@ -530,7 +530,7 @@ int qemuDomainAttachSCSIDisk(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
@ -619,12 +619,12 @@ int qemuDomainAttachUsbMassstorageDevice(virConnectPtr conn,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->caps) < 0)
|
if (qemuAssignDeviceDiskAlias(vm->def, disk, priv->qemuCaps) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->caps)))
|
if (!(drivestr = qemuBuildDriveStr(conn, disk, false, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
if (!(devstr = qemuBuildDriveDevStr(NULL, disk, 0, priv->caps)))
|
if (!(devstr = qemuBuildDriveDevStr(NULL, disk, 0, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -634,7 +634,7 @@ int qemuDomainAttachUsbMassstorageDevice(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
ret = qemuMonitorAddDrive(priv->mon, drivestr);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
@ -723,7 +723,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_HOST_NET_ADD)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_HOST_NET_ADD)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("installed qemu version does not support host_net_add"));
|
_("installed qemu version does not support host_net_add"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -738,38 +738,38 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
*/
|
*/
|
||||||
if (actualType == VIR_DOMAIN_NET_TYPE_NETWORK ||
|
if (actualType == VIR_DOMAIN_NET_TYPE_NETWORK ||
|
||||||
cfg->privileged ||
|
cfg->privileged ||
|
||||||
(!qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV_BRIDGE))) {
|
(!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV_BRIDGE))) {
|
||||||
if ((tapfd = qemuNetworkIfaceConnect(vm->def, conn, driver, net,
|
if ((tapfd = qemuNetworkIfaceConnect(vm->def, conn, driver, net,
|
||||||
priv->caps)) < 0)
|
priv->qemuCaps)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
iface_connected = true;
|
iface_connected = true;
|
||||||
if (qemuOpenVhostNet(vm->def, net, priv->caps, &vhostfd) < 0)
|
if (qemuOpenVhostNet(vm->def, net, priv->qemuCaps, &vhostfd) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
} else if (actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
} else if (actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
||||||
if ((tapfd = qemuPhysIfaceConnect(vm->def, driver, net,
|
if ((tapfd = qemuPhysIfaceConnect(vm->def, driver, net,
|
||||||
priv->caps,
|
priv->qemuCaps,
|
||||||
VIR_NETDEV_VPORT_PROFILE_OP_CREATE)) < 0)
|
VIR_NETDEV_VPORT_PROFILE_OP_CREATE)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
iface_connected = true;
|
iface_connected = true;
|
||||||
if (qemuOpenVhostNet(vm->def, net, priv->caps, &vhostfd) < 0)
|
if (qemuOpenVhostNet(vm->def, net, priv->qemuCaps, &vhostfd) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NET_NAME) ||
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NET_NAME) ||
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceNetAlias(vm->def, net, -1) < 0)
|
if (qemuAssignDeviceNetAlias(vm->def, net, -1) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &net->info) < 0)
|
qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, &net->info) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
releaseaddr = true;
|
releaseaddr = true;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
vlan = -1;
|
vlan = -1;
|
||||||
} else {
|
} else {
|
||||||
vlan = qemuDomainNetVLAN(net);
|
vlan = qemuDomainNetVLAN(net);
|
||||||
@ -791,22 +791,22 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
goto no_memory;
|
goto no_memory;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (!(netstr = qemuBuildHostNetStr(net, driver, priv->caps,
|
if (!(netstr = qemuBuildHostNetStr(net, driver, priv->qemuCaps,
|
||||||
',', -1, tapfd_name,
|
',', -1, tapfd_name,
|
||||||
vhostfd_name)))
|
vhostfd_name)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
} else {
|
} else {
|
||||||
if (!(netstr = qemuBuildHostNetStr(net, driver, priv->caps,
|
if (!(netstr = qemuBuildHostNetStr(net, driver, priv->qemuCaps,
|
||||||
' ', vlan, tapfd_name,
|
' ', vlan, tapfd_name,
|
||||||
vhostfd_name)))
|
vhostfd_name)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorAddNetdev(priv->mon, netstr, tapfd, tapfd_name,
|
if (qemuMonitorAddNetdev(priv->mon, netstr, tapfd, tapfd_name,
|
||||||
vhostfd, vhostfd_name) < 0) {
|
vhostfd, vhostfd_name) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
@ -832,8 +832,8 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (!(nicstr = qemuBuildNicDevStr(net, vlan, 0, priv->caps)))
|
if (!(nicstr = qemuBuildNicDevStr(net, vlan, 0, priv->qemuCaps)))
|
||||||
goto try_remove;
|
goto try_remove;
|
||||||
} else {
|
} else {
|
||||||
if (!(nicstr = qemuBuildNicStr(net, NULL, vlan)))
|
if (!(nicstr = qemuBuildNicStr(net, NULL, vlan)))
|
||||||
@ -841,7 +841,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorAddDevice(priv->mon, nicstr) < 0) {
|
if (qemuMonitorAddDevice(priv->mon, nicstr) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
virDomainAuditNet(vm, NULL, net, "attach", false);
|
virDomainAuditNet(vm, NULL, net, "attach", false);
|
||||||
@ -868,7 +868,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
} else {
|
} else {
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV)) {
|
||||||
if (qemuMonitorSetLink(priv->mon, net->info.alias, VIR_DOMAIN_NET_INTERFACE_LINK_STATE_DOWN) < 0) {
|
if (qemuMonitorSetLink(priv->mon, net->info.alias, VIR_DOMAIN_NET_INTERFACE_LINK_STATE_DOWN) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
virDomainAuditNet(vm, NULL, net, "attach", false);
|
virDomainAuditNet(vm, NULL, net, "attach", false);
|
||||||
@ -892,7 +892,7 @@ cleanup:
|
|||||||
if (!ret) {
|
if (!ret) {
|
||||||
vm->def->nets[vm->def->nnets++] = net;
|
vm->def->nets[vm->def->nnets++] = net;
|
||||||
} else {
|
} else {
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
(net->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
(net->info.type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
||||||
releaseaddr &&
|
releaseaddr &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
@ -926,8 +926,8 @@ try_remove:
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (vlan < 0) {
|
if (vlan < 0) {
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
char *netdev_name;
|
char *netdev_name;
|
||||||
if (virAsprintf(&netdev_name, "host%s", net->info.alias) < 0)
|
if (virAsprintf(&netdev_name, "host%s", net->info.alias) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
@ -979,13 +979,13 @@ int qemuDomainAttachHostPciDevice(virQEMUDriverPtr driver,
|
|||||||
&hostdev, 1) < 0)
|
&hostdev, 1) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceHostdevAlias(vm->def, hostdev, -1) < 0)
|
if (qemuAssignDeviceHostdevAlias(vm->def, hostdev, -1) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, hostdev->info) < 0)
|
if (qemuDomainPCIAddressEnsureAddr(priv->pciaddrs, hostdev->info) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
releaseaddr = true;
|
releaseaddr = true;
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_PCI_CONFIGFD)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_PCI_CONFIGFD)) {
|
||||||
configfd = qemuOpenPCIConfig(hostdev);
|
configfd = qemuOpenPCIConfig(hostdev);
|
||||||
if (configfd >= 0) {
|
if (configfd >= 0) {
|
||||||
if (virAsprintf(&configfd_name, "fd-%s",
|
if (virAsprintf(&configfd_name, "fd-%s",
|
||||||
@ -1003,7 +1003,7 @@ int qemuDomainAttachHostPciDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!(devstr = qemuBuildPCIHostdevDevStr(hostdev, configfd_name,
|
if (!(devstr = qemuBuildPCIHostdevDevStr(hostdev, configfd_name,
|
||||||
priv->caps)))
|
priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
@ -1035,7 +1035,7 @@ int qemuDomainAttachHostPciDevice(virQEMUDriverPtr driver,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
(hostdev->info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
(hostdev->info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) &&
|
||||||
releaseaddr &&
|
releaseaddr &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
@ -1061,10 +1061,10 @@ int qemuDomainAttachRedirdevDevice(virQEMUDriverPtr driver,
|
|||||||
virDomainDefPtr def = vm->def;
|
virDomainDefPtr def = vm->def;
|
||||||
char *devstr = NULL;
|
char *devstr = NULL;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceRedirdevAlias(vm->def, redirdev, -1) < 0)
|
if (qemuAssignDeviceRedirdevAlias(vm->def, redirdev, -1) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
if (!(devstr = qemuBuildRedirdevDevStr(def, redirdev, priv->caps)))
|
if (!(devstr = qemuBuildRedirdevDevStr(def, redirdev, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1074,7 +1074,7 @@ int qemuDomainAttachRedirdevDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE))
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE))
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
else
|
else
|
||||||
goto error;
|
goto error;
|
||||||
@ -1104,10 +1104,10 @@ int qemuDomainAttachHostUsbDevice(virQEMUDriverPtr driver,
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
char *devstr = NULL;
|
char *devstr = NULL;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceHostdevAlias(vm->def, hostdev, -1) < 0)
|
if (qemuAssignDeviceHostdevAlias(vm->def, hostdev, -1) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
if (!(devstr = qemuBuildUSBHostdevDevStr(hostdev, priv->caps)))
|
if (!(devstr = qemuBuildUSBHostdevDevStr(hostdev, priv->qemuCaps)))
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1144,7 +1144,7 @@ int qemuDomainAttachHostUsbDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE))
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE))
|
||||||
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
ret = qemuMonitorAddDevice(priv->mon, devstr);
|
||||||
else
|
else
|
||||||
ret = qemuMonitorAddUSBDeviceExact(priv->mon,
|
ret = qemuMonitorAddUSBDeviceExact(priv->mon,
|
||||||
@ -2057,7 +2057,7 @@ int qemuDomainDetachPciDiskDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorDelDevice(priv->mon, detach->info.alias) < 0) {
|
if (qemuMonitorDelDevice(priv->mon, detach->info.alias) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
virDomainAuditDisk(vm, detach->src, NULL, "detach", false);
|
virDomainAuditDisk(vm, detach->src, NULL, "detach", false);
|
||||||
@ -2079,7 +2079,7 @@ int qemuDomainDetachPciDiskDevice(virQEMUDriverPtr driver,
|
|||||||
|
|
||||||
virDomainAuditDisk(vm, detach->src, NULL, "detach", true);
|
virDomainAuditDisk(vm, detach->src, NULL, "detach", true);
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
detach->info.addr.pci.slot) < 0)
|
detach->info.addr.pci.slot) < 0)
|
||||||
VIR_WARN("Unable to release PCI address on %s", dev->data.disk->src);
|
VIR_WARN("Unable to release PCI address on %s", dev->data.disk->src);
|
||||||
@ -2129,7 +2129,7 @@ int qemuDomainDetachDiskDevice(virQEMUDriverPtr driver,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
virReportError(VIR_ERR_OPERATION_FAILED,
|
virReportError(VIR_ERR_OPERATION_FAILED,
|
||||||
_("Underlying qemu does not support %s disk removal"),
|
_("Underlying qemu does not support %s disk removal"),
|
||||||
virDomainDiskBusTypeToString(dev->data.disk->bus));
|
virDomainDiskBusTypeToString(dev->data.disk->bus));
|
||||||
@ -2293,13 +2293,13 @@ int qemuDomainDetachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuAssignDeviceControllerAlias(detach) < 0)
|
if (qemuAssignDeviceControllerAlias(detach) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorDelDevice(priv->mon, detach->info.alias)) {
|
if (qemuMonitorDelDevice(priv->mon, detach->info.alias)) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -2316,7 +2316,7 @@ int qemuDomainDetachPciControllerDevice(virQEMUDriverPtr driver,
|
|||||||
virDomainControllerRemove(vm->def, idx);
|
virDomainControllerRemove(vm->def, idx);
|
||||||
virDomainControllerDefFree(detach);
|
virDomainControllerDefFree(detach);
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
detach->info.addr.pci.slot) < 0)
|
detach->info.addr.pci.slot) < 0)
|
||||||
VIR_WARN("Unable to release PCI address on controller");
|
VIR_WARN("Unable to release PCI address on controller");
|
||||||
@ -2355,7 +2355,7 @@ qemuDomainDetachHostPciDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
rv = qemuMonitorDelDevice(priv->mon, detach->info->alias);
|
rv = qemuMonitorDelDevice(priv->mon, detach->info->alias);
|
||||||
} else {
|
} else {
|
||||||
rv = qemuMonitorRemovePCIDevice(priv->mon, &detach->info->addr.pci);
|
rv = qemuMonitorRemovePCIDevice(priv->mon, &detach->info->addr.pci);
|
||||||
@ -2392,7 +2392,7 @@ qemuDomainDetachHostPciDevice(virQEMUDriverPtr driver,
|
|||||||
virObjectUnlock(driver->activePciHostdevs);
|
virObjectUnlock(driver->activePciHostdevs);
|
||||||
virObjectUnlock(driver->inactivePciHostdevs);
|
virObjectUnlock(driver->inactivePciHostdevs);
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
detach->info->addr.pci.slot) < 0)
|
detach->info->addr.pci.slot) < 0)
|
||||||
VIR_WARN("Unable to release PCI address on host device");
|
VIR_WARN("Unable to release PCI address on host device");
|
||||||
@ -2418,7 +2418,7 @@ qemuDomainDetachHostUsbDevice(virQEMUDriverPtr driver,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
virReportError(VIR_ERR_OPERATION_FAILED,
|
virReportError(VIR_ERR_OPERATION_FAILED,
|
||||||
"%s", _("device cannot be detached with this QEMU version"));
|
"%s", _("device cannot be detached with this QEMU version"));
|
||||||
return -1;
|
return -1;
|
||||||
@ -2611,7 +2611,7 @@ qemuDomainDetachNetDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorDelDevice(priv->mon, detach->info.alias) < 0) {
|
if (qemuMonitorDelDevice(priv->mon, detach->info.alias) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
virDomainAuditNet(vm, detach, NULL, "detach", false);
|
virDomainAuditNet(vm, detach, NULL, "detach", false);
|
||||||
@ -2626,8 +2626,8 @@ qemuDomainDetachNetDevice(virQEMUDriverPtr driver,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV) &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuMonitorRemoveNetdev(priv->mon, hostnet_name) < 0) {
|
if (qemuMonitorRemoveNetdev(priv->mon, hostnet_name) < 0) {
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
virDomainAuditNet(vm, detach, NULL, "detach", false);
|
virDomainAuditNet(vm, detach, NULL, "detach", false);
|
||||||
@ -2644,7 +2644,7 @@ qemuDomainDetachNetDevice(virQEMUDriverPtr driver,
|
|||||||
|
|
||||||
virDomainAuditNet(vm, detach, NULL, "detach", true);
|
virDomainAuditNet(vm, detach, NULL, "detach", true);
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE) &&
|
||||||
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
qemuDomainPCIAddressReleaseSlot(priv->pciaddrs,
|
||||||
detach->info.addr.pci.slot) < 0)
|
detach->info.addr.pci.slot) < 0)
|
||||||
VIR_WARN("Unable to release PCI address on NIC");
|
VIR_WARN("Unable to release PCI address on NIC");
|
||||||
|
@ -1162,7 +1162,7 @@ qemuMigrationUpdateJobStatus(virQEMUDriverPtr driver,
|
|||||||
* migration finish until SPICE server transfers its data */
|
* migration finish until SPICE server transfers its data */
|
||||||
if (vm->def->ngraphics == 1 &&
|
if (vm->def->ngraphics == 1 &&
|
||||||
vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_SPICE &&
|
vm->def->graphics[0]->type == VIR_DOMAIN_GRAPHICS_TYPE_SPICE &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_SEAMLESS_MIGRATION))
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_SEAMLESS_MIGRATION))
|
||||||
wait_for_spice = true;
|
wait_for_spice = true;
|
||||||
|
|
||||||
ret = qemuDomainObjEnterMonitorAsync(driver, vm, asyncJob);
|
ret = qemuDomainObjEnterMonitorAsync(driver, vm, asyncJob);
|
||||||
@ -2286,7 +2286,7 @@ qemuMigrationRun(virQEMUDriverPtr driver,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case MIGRATION_DEST_UNIX:
|
case MIGRATION_DEST_UNIX:
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_UNIX)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_UNIX)) {
|
||||||
ret = qemuMonitorMigrateToUnix(priv->mon, migrate_flags,
|
ret = qemuMonitorMigrateToUnix(priv->mon, migrate_flags,
|
||||||
spec->dest.unix_socket.file);
|
spec->dest.unix_socket.file);
|
||||||
} else {
|
} else {
|
||||||
@ -2441,7 +2441,7 @@ static int doNativeMigrate(virQEMUDriverPtr driver,
|
|||||||
if (!uribits)
|
if (!uribits)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_FD))
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD))
|
||||||
spec.destType = MIGRATION_DEST_CONNECT_HOST;
|
spec.destType = MIGRATION_DEST_CONNECT_HOST;
|
||||||
else
|
else
|
||||||
spec.destType = MIGRATION_DEST_HOST;
|
spec.destType = MIGRATION_DEST_HOST;
|
||||||
@ -2483,9 +2483,9 @@ static int doTunnelMigrate(virQEMUDriverPtr driver,
|
|||||||
driver, vm, st, NULLSTR(cookiein), cookieinlen,
|
driver, vm, st, NULLSTR(cookiein), cookieinlen,
|
||||||
cookieout, cookieoutlen, flags, resource);
|
cookieout, cookieoutlen, flags, resource);
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
||||||
!qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_UNIX) &&
|
!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_UNIX) &&
|
||||||
!qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_EXEC)) {
|
!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_EXEC)) {
|
||||||
virReportError(VIR_ERR_OPERATION_FAILED, "%s",
|
virReportError(VIR_ERR_OPERATION_FAILED, "%s",
|
||||||
_("Source qemu is too old to support tunnelled migration"));
|
_("Source qemu is too old to support tunnelled migration"));
|
||||||
virObjectUnref(cfg);
|
virObjectUnref(cfg);
|
||||||
@ -2495,7 +2495,7 @@ static int doTunnelMigrate(virQEMUDriverPtr driver,
|
|||||||
spec.fwdType = MIGRATION_FWD_STREAM;
|
spec.fwdType = MIGRATION_FWD_STREAM;
|
||||||
spec.fwd.stream = st;
|
spec.fwd.stream = st;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_FD)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD)) {
|
||||||
int fds[2];
|
int fds[2];
|
||||||
|
|
||||||
spec.destType = MIGRATION_DEST_FD;
|
spec.destType = MIGRATION_DEST_FD;
|
||||||
@ -3623,7 +3623,7 @@ qemuMigrationToFile(virQEMUDriverPtr driver, virDomainObjPtr vm,
|
|||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
||||||
(!compressor || pipe(pipeFD) == 0)) {
|
(!compressor || pipe(pipeFD) == 0)) {
|
||||||
/* All right! We can use fd migration, which means that qemu
|
/* All right! We can use fd migration, which means that qemu
|
||||||
* doesn't have to open() the file, so while we still have to
|
* doesn't have to open() the file, so while we still have to
|
||||||
@ -3674,7 +3674,7 @@ qemuMigrationToFile(virQEMUDriverPtr driver, virDomainObjPtr vm,
|
|||||||
if (!compressor) {
|
if (!compressor) {
|
||||||
const char *args[] = { "cat", NULL };
|
const char *args[] = { "cat", NULL };
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MIGRATE_QEMU_FD) &&
|
||||||
priv->monConfig->type == VIR_DOMAIN_CHR_TYPE_UNIX) {
|
priv->monConfig->type == VIR_DOMAIN_CHR_TYPE_UNIX) {
|
||||||
rc = qemuMonitorMigrateToFd(priv->mon,
|
rc = qemuMonitorMigrateToFd(priv->mon,
|
||||||
QEMU_MONITOR_MIGRATE_BACKGROUND,
|
QEMU_MONITOR_MIGRATE_BACKGROUND,
|
||||||
|
@ -1414,8 +1414,8 @@ qemuConnectMonitor(virQEMUDriverPtr driver, virDomainObjPtr vm)
|
|||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
ret = qemuMonitorSetCapabilities(priv->mon);
|
ret = qemuMonitorSetCapabilities(priv->mon);
|
||||||
if (ret == 0 &&
|
if (ret == 0 &&
|
||||||
qemuCapsGet(priv->caps, QEMU_CAPS_MONITOR_JSON))
|
virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MONITOR_JSON))
|
||||||
ret = qemuCapsProbeQMP(priv->caps, priv->mon);
|
ret = virQEMUCapsProbeQMP(priv->qemuCaps, priv->mon);
|
||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -1625,10 +1625,10 @@ qemuProcessLookupPTYs(virDomainChrDefPtr *devices,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
qemuProcessFindCharDevicePTYsMonitor(virDomainObjPtr vm,
|
qemuProcessFindCharDevicePTYsMonitor(virDomainObjPtr vm,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
virHashTablePtr paths)
|
virHashTablePtr paths)
|
||||||
{
|
{
|
||||||
bool chardevfmt = qemuCapsGet(caps, QEMU_CAPS_CHARDEV);
|
bool chardevfmt = virQEMUCapsGet(qemuCaps, QEMU_CAPS_CHARDEV);
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
if (qemuProcessLookupPTYs(vm->def->serials, vm->def->nserials,
|
if (qemuProcessLookupPTYs(vm->def->serials, vm->def->nserials,
|
||||||
@ -1753,7 +1753,7 @@ qemuProcessReadLogFD(int logfd, char *buf, int maxlen, int off)
|
|||||||
static int
|
static int
|
||||||
qemuProcessWaitForMonitor(virQEMUDriverPtr driver,
|
qemuProcessWaitForMonitor(virQEMUDriverPtr driver,
|
||||||
virDomainObjPtr vm,
|
virDomainObjPtr vm,
|
||||||
qemuCapsPtr caps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
off_t pos)
|
off_t pos)
|
||||||
{
|
{
|
||||||
char *buf = NULL;
|
char *buf = NULL;
|
||||||
@ -1763,7 +1763,7 @@ qemuProcessWaitForMonitor(virQEMUDriverPtr driver,
|
|||||||
virHashTablePtr paths = NULL;
|
virHashTablePtr paths = NULL;
|
||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv;
|
||||||
|
|
||||||
if (!qemuCapsUsedQMP(caps) && pos != -1) {
|
if (!virQEMUCapsUsedQMP(qemuCaps) && pos != -1) {
|
||||||
if ((logfd = qemuDomainOpenLog(driver, vm, pos)) < 0)
|
if ((logfd = qemuDomainOpenLog(driver, vm, pos)) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -1798,7 +1798,7 @@ qemuProcessWaitForMonitor(virQEMUDriverPtr driver,
|
|||||||
|
|
||||||
VIR_DEBUG("qemuMonitorGetPtyPaths returned %i", ret);
|
VIR_DEBUG("qemuMonitorGetPtyPaths returned %i", ret);
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
ret = qemuProcessFindCharDevicePTYsMonitor(vm, caps, paths);
|
ret = qemuProcessFindCharDevicePTYsMonitor(vm, qemuCaps, paths);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virHashFree(paths);
|
virHashFree(paths);
|
||||||
@ -1806,7 +1806,7 @@ cleanup:
|
|||||||
if (pos != -1 && kill(vm->pid, 0) == -1 && errno == ESRCH) {
|
if (pos != -1 && kill(vm->pid, 0) == -1 && errno == ESRCH) {
|
||||||
/* VM is dead, any other error raised in the interim is probably
|
/* VM is dead, any other error raised in the interim is probably
|
||||||
* not as important as the qemu cmdline output */
|
* not as important as the qemu cmdline output */
|
||||||
if (qemuCapsUsedQMP(caps)) {
|
if (virQEMUCapsUsedQMP(qemuCaps)) {
|
||||||
if ((logfd = qemuDomainOpenLog(driver, vm, pos)) < 0)
|
if ((logfd = qemuDomainOpenLog(driver, vm, pos)) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -2124,7 +2124,7 @@ qemuProcessSetLinkStates(virDomainObjPtr vm)
|
|||||||
if (def->nets[i]->linkstate == VIR_DOMAIN_NET_INTERFACE_LINK_STATE_DOWN) {
|
if (def->nets[i]->linkstate == VIR_DOMAIN_NET_INTERFACE_LINK_STATE_DOWN) {
|
||||||
VIR_DEBUG("Setting link state: %s", def->nets[i]->info.alias);
|
VIR_DEBUG("Setting link state: %s", def->nets[i]->info.alias);
|
||||||
|
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_NETDEV)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NETDEV)) {
|
||||||
virReportError(VIR_ERR_NO_SUPPORT, "%s",
|
virReportError(VIR_ERR_NO_SUPPORT, "%s",
|
||||||
_("Setting of link state is not supported by this qemu"));
|
_("Setting of link state is not supported by this qemu"));
|
||||||
return -1;
|
return -1;
|
||||||
@ -2225,7 +2225,7 @@ qemuProcessInitPasswords(virConnectPtr conn,
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
for (i = 0 ; i < vm->def->ndisks ; i++) {
|
for (i = 0 ; i < vm->def->ndisks ; i++) {
|
||||||
char *secret;
|
char *secret;
|
||||||
size_t secretLen;
|
size_t secretLen;
|
||||||
@ -3237,14 +3237,14 @@ qemuProcessReconnect(void *opaque)
|
|||||||
/* If upgrading from old libvirtd we won't have found any
|
/* If upgrading from old libvirtd we won't have found any
|
||||||
* caps in the domain status, so re-query them
|
* caps in the domain status, so re-query them
|
||||||
*/
|
*/
|
||||||
if (!priv->caps &&
|
if (!priv->qemuCaps &&
|
||||||
!(priv->caps = qemuCapsCacheLookupCopy(driver->capsCache,
|
!(priv->qemuCaps = virQEMUCapsCacheLookupCopy(driver->qemuCapsCache,
|
||||||
obj->def->emulator)))
|
obj->def->emulator)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
/* In case the domain shutdown while we were not running,
|
/* In case the domain shutdown while we were not running,
|
||||||
* we need to finish the shutdown process. And we need to do it after
|
* we need to finish the shutdown process. And we need to do it after
|
||||||
* we have qemuCaps filled in.
|
* we have virQEMUCaps filled in.
|
||||||
*/
|
*/
|
||||||
if (state == VIR_DOMAIN_SHUTDOWN ||
|
if (state == VIR_DOMAIN_SHUTDOWN ||
|
||||||
(state == VIR_DOMAIN_PAUSED &&
|
(state == VIR_DOMAIN_PAUSED &&
|
||||||
@ -3255,8 +3255,8 @@ qemuProcessReconnect(void *opaque)
|
|||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE))
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE))
|
||||||
if ((qemuDomainAssignAddresses(obj->def, priv->caps, obj)) < 0)
|
if ((qemuDomainAssignAddresses(obj->def, priv->qemuCaps, obj)) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (virSecurityManagerReserveLabel(driver->securityManager, obj->def, obj->pid) < 0)
|
if (virSecurityManagerReserveLabel(driver->securityManager, obj->def, obj->pid) < 0)
|
||||||
@ -3330,7 +3330,7 @@ error:
|
|||||||
* to remove danger of it ending up running twice if
|
* to remove danger of it ending up running twice if
|
||||||
* user tries to start it again later
|
* user tries to start it again later
|
||||||
*/
|
*/
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_NO_SHUTDOWN)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NO_SHUTDOWN)) {
|
||||||
/* If we couldn't get the monitor and qemu supports
|
/* If we couldn't get the monitor and qemu supports
|
||||||
* no-shutdown, we can safely say that the domain
|
* no-shutdown, we can safely say that the domain
|
||||||
* crashed ... */
|
* crashed ... */
|
||||||
@ -3732,12 +3732,12 @@ int qemuProcessStart(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
VIR_DEBUG("Determining emulator version");
|
VIR_DEBUG("Determining emulator version");
|
||||||
virObjectUnref(priv->caps);
|
virObjectUnref(priv->qemuCaps);
|
||||||
if (!(priv->caps = qemuCapsCacheLookupCopy(driver->capsCache,
|
if (!(priv->qemuCaps = virQEMUCapsCacheLookupCopy(driver->qemuCapsCache,
|
||||||
vm->def->emulator)))
|
vm->def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuAssignDeviceAliases(vm->def, priv->caps) < 0)
|
if (qemuAssignDeviceAliases(vm->def, priv->qemuCaps) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
VIR_DEBUG("Checking for CDROM and floppy presence");
|
VIR_DEBUG("Checking for CDROM and floppy presence");
|
||||||
@ -3777,7 +3777,7 @@ int qemuProcessStart(virConnectPtr conn,
|
|||||||
if (qemuProcessPrepareMonitorChr(cfg, priv->monConfig, vm->def->name) < 0)
|
if (qemuProcessPrepareMonitorChr(cfg, priv->monConfig, vm->def->name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_MONITOR_JSON))
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_MONITOR_JSON))
|
||||||
priv->monJSON = 1;
|
priv->monJSON = 1;
|
||||||
else
|
else
|
||||||
priv->monJSON = 0;
|
priv->monJSON = 0;
|
||||||
@ -3808,15 +3808,15 @@ int qemuProcessStart(virConnectPtr conn,
|
|||||||
* we also need to populate the PCi address set cache for later
|
* we also need to populate the PCi address set cache for later
|
||||||
* use in hotplug
|
* use in hotplug
|
||||||
*/
|
*/
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
VIR_DEBUG("Assigning domain PCI addresses");
|
VIR_DEBUG("Assigning domain PCI addresses");
|
||||||
if ((qemuDomainAssignAddresses(vm->def, priv->caps, vm)) < 0)
|
if ((qemuDomainAssignAddresses(vm->def, priv->qemuCaps, vm)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
VIR_DEBUG("Building emulator command line");
|
VIR_DEBUG("Building emulator command line");
|
||||||
if (!(cmd = qemuBuildCommandLine(conn, driver, vm->def, priv->monConfig,
|
if (!(cmd = qemuBuildCommandLine(conn, driver, vm->def, priv->monConfig,
|
||||||
priv->monJSON != 0, priv->caps,
|
priv->monJSON != 0, priv->qemuCaps,
|
||||||
migrateFrom, stdin_fd, snapshot, vmop)))
|
migrateFrom, stdin_fd, snapshot, vmop)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -3979,7 +3979,7 @@ int qemuProcessStart(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
VIR_DEBUG("Waiting for monitor to show up");
|
VIR_DEBUG("Waiting for monitor to show up");
|
||||||
if (qemuProcessWaitForMonitor(driver, vm, priv->caps, pos) < 0)
|
if (qemuProcessWaitForMonitor(driver, vm, priv->qemuCaps, pos) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
/* Failure to connect to agent shouldn't be fatal */
|
/* Failure to connect to agent shouldn't be fatal */
|
||||||
@ -4016,7 +4016,7 @@ int qemuProcessStart(virConnectPtr conn,
|
|||||||
|
|
||||||
/* If we have -device, then addresses are assigned explicitly.
|
/* If we have -device, then addresses are assigned explicitly.
|
||||||
* If not, then we have to detect dynamic ones here */
|
* If not, then we have to detect dynamic ones here */
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
VIR_DEBUG("Determining domain device PCI addresses");
|
VIR_DEBUG("Determining domain device PCI addresses");
|
||||||
if (qemuProcessInitPCIAddresses(driver, vm) < 0)
|
if (qemuProcessInitPCIAddresses(driver, vm) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -4370,8 +4370,8 @@ retry:
|
|||||||
virDomainObjSetState(vm, VIR_DOMAIN_SHUTOFF, reason);
|
virDomainObjSetState(vm, VIR_DOMAIN_SHUTOFF, reason);
|
||||||
VIR_FREE(priv->vcpupids);
|
VIR_FREE(priv->vcpupids);
|
||||||
priv->nvcpupids = 0;
|
priv->nvcpupids = 0;
|
||||||
virObjectUnref(priv->caps);
|
virObjectUnref(priv->qemuCaps);
|
||||||
priv->caps = NULL;
|
priv->qemuCaps = NULL;
|
||||||
VIR_FREE(priv->pidfile);
|
VIR_FREE(priv->pidfile);
|
||||||
|
|
||||||
/* The "release" hook cleans up additional resources */
|
/* The "release" hook cleans up additional resources */
|
||||||
@ -4488,8 +4488,8 @@ int qemuProcessAttach(virConnectPtr conn ATTRIBUTE_UNUSED,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
VIR_DEBUG("Determining emulator version");
|
VIR_DEBUG("Determining emulator version");
|
||||||
virObjectUnref(priv->caps);
|
virObjectUnref(priv->qemuCaps);
|
||||||
if (!(priv->caps = qemuCapsCacheLookupCopy(driver->capsCache,
|
if (!(priv->qemuCaps = virQEMUCapsCacheLookupCopy(driver->qemuCapsCache,
|
||||||
vm->def->emulator)))
|
vm->def->emulator)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -4507,9 +4507,9 @@ int qemuProcessAttach(virConnectPtr conn ATTRIBUTE_UNUSED,
|
|||||||
* we also need to populate the PCi address set cache for later
|
* we also need to populate the PCi address set cache for later
|
||||||
* use in hotplug
|
* use in hotplug
|
||||||
*/
|
*/
|
||||||
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
VIR_DEBUG("Assigning domain PCI addresses");
|
VIR_DEBUG("Assigning domain PCI addresses");
|
||||||
if ((qemuDomainAssignAddresses(vm->def, priv->caps, vm)) < 0)
|
if ((qemuDomainAssignAddresses(vm->def, priv->qemuCaps, vm)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4531,7 +4531,7 @@ int qemuProcessAttach(virConnectPtr conn ATTRIBUTE_UNUSED,
|
|||||||
vm->pid = pid;
|
vm->pid = pid;
|
||||||
|
|
||||||
VIR_DEBUG("Waiting for monitor to show up");
|
VIR_DEBUG("Waiting for monitor to show up");
|
||||||
if (qemuProcessWaitForMonitor(driver, vm, priv->caps, -1) < 0)
|
if (qemuProcessWaitForMonitor(driver, vm, priv->qemuCaps, -1) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
/* Failure to connect to agent shouldn't be fatal */
|
/* Failure to connect to agent shouldn't be fatal */
|
||||||
@ -4548,7 +4548,7 @@ int qemuProcessAttach(virConnectPtr conn ATTRIBUTE_UNUSED,
|
|||||||
|
|
||||||
/* If we have -device, then addresses are assigned explicitly.
|
/* If we have -device, then addresses are assigned explicitly.
|
||||||
* If not, then we have to detect dynamic ones here */
|
* If not, then we have to detect dynamic ones here */
|
||||||
if (!qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DEVICE)) {
|
||||||
VIR_DEBUG("Determining domain device PCI addresses");
|
VIR_DEBUG("Determining domain device PCI addresses");
|
||||||
if (qemuProcessInitPCIAddresses(driver, vm) < 0)
|
if (qemuProcessInitPCIAddresses(driver, vm) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -11,20 +11,20 @@
|
|||||||
|
|
||||||
struct testInfo {
|
struct testInfo {
|
||||||
const char *name;
|
const char *name;
|
||||||
qemuCapsPtr flags;
|
virQEMUCapsPtr flags;
|
||||||
unsigned int version;
|
unsigned int version;
|
||||||
unsigned int is_kvm;
|
unsigned int is_kvm;
|
||||||
unsigned int kvm_version;
|
unsigned int kvm_version;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void printMismatchedFlags(qemuCapsPtr got,
|
static void printMismatchedFlags(virQEMUCapsPtr got,
|
||||||
qemuCapsPtr expect)
|
virQEMUCapsPtr expect)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0 ; i < QEMU_CAPS_LAST ; i++) {
|
for (i = 0 ; i < QEMU_CAPS_LAST ; i++) {
|
||||||
bool gotFlag = qemuCapsGet(got, i);
|
bool gotFlag = virQEMUCapsGet(got, i);
|
||||||
bool expectFlag = qemuCapsGet(expect, i);
|
bool expectFlag = virQEMUCapsGet(expect, i);
|
||||||
if (gotFlag && !expectFlag)
|
if (gotFlag && !expectFlag)
|
||||||
fprintf(stderr, "Extra flag %i\n", i);
|
fprintf(stderr, "Extra flag %i\n", i);
|
||||||
if (!gotFlag && expectFlag)
|
if (!gotFlag && expectFlag)
|
||||||
@ -38,7 +38,7 @@ static int testHelpStrParsing(const void *data)
|
|||||||
char *path = NULL;
|
char *path = NULL;
|
||||||
char *help = NULL;
|
char *help = NULL;
|
||||||
unsigned int version, is_kvm, kvm_version;
|
unsigned int version, is_kvm, kvm_version;
|
||||||
qemuCapsPtr flags = NULL;
|
virQEMUCapsPtr flags = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
char *got = NULL;
|
char *got = NULL;
|
||||||
char *expected = NULL;
|
char *expected = NULL;
|
||||||
@ -49,19 +49,19 @@ static int testHelpStrParsing(const void *data)
|
|||||||
if (virtTestLoadFile(path, &help) < 0)
|
if (virtTestLoadFile(path, &help) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(flags = qemuCapsNew()))
|
if (!(flags = virQEMUCapsNew()))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCapsParseHelpStr("QEMU", help, flags,
|
if (virQEMUCapsParseHelpStr("QEMU", help, flags,
|
||||||
&version, &is_kvm, &kvm_version, false) == -1)
|
&version, &is_kvm, &kvm_version, false) == -1)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
# ifndef WITH_YAJL
|
# ifndef WITH_YAJL
|
||||||
if (qemuCapsGet(info->flags, QEMU_CAPS_MONITOR_JSON))
|
if (virQEMUCapsGet(info->flags, QEMU_CAPS_MONITOR_JSON))
|
||||||
qemuCapsSet(flags, QEMU_CAPS_MONITOR_JSON);
|
virQEMUCapsSet(flags, QEMU_CAPS_MONITOR_JSON);
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
if (qemuCapsGet(info->flags, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(info->flags, QEMU_CAPS_DEVICE)) {
|
||||||
VIR_FREE(path);
|
VIR_FREE(path);
|
||||||
VIR_FREE(help);
|
VIR_FREE(help);
|
||||||
if (virAsprintf(&path, "%s/qemuhelpdata/%s-device", abs_srcdir,
|
if (virAsprintf(&path, "%s/qemuhelpdata/%s-device", abs_srcdir,
|
||||||
@ -71,12 +71,12 @@ static int testHelpStrParsing(const void *data)
|
|||||||
if (virtTestLoadFile(path, &help) < 0)
|
if (virtTestLoadFile(path, &help) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCapsParseDeviceStr(flags, help) < 0)
|
if (virQEMUCapsParseDeviceStr(flags, help) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
got = qemuCapsFlagsString(flags);
|
got = virQEMUCapsFlagsString(flags);
|
||||||
expected = qemuCapsFlagsString(info->flags);
|
expected = virQEMUCapsFlagsString(info->flags);
|
||||||
if (!got || !expected)
|
if (!got || !expected)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -132,9 +132,9 @@ mymain(void)
|
|||||||
struct testInfo info = { \
|
struct testInfo info = { \
|
||||||
name, NULL, version, is_kvm, kvm_version \
|
name, NULL, version, is_kvm, kvm_version \
|
||||||
}; \
|
}; \
|
||||||
if (!(info.flags = qemuCapsNew())) \
|
if (!(info.flags = virQEMUCapsNew())) \
|
||||||
return EXIT_FAILURE; \
|
return EXIT_FAILURE; \
|
||||||
qemuCapsSetList(info.flags, __VA_ARGS__, QEMU_CAPS_LAST); \
|
virQEMUCapsSetList(info.flags, __VA_ARGS__, QEMU_CAPS_LAST); \
|
||||||
if (virtTestRun("QEMU Help String Parsing " name, \
|
if (virtTestRun("QEMU Help String Parsing " name, \
|
||||||
1, testHelpStrParsing, &info) < 0) \
|
1, testHelpStrParsing, &info) < 0) \
|
||||||
ret = -1; \
|
ret = -1; \
|
||||||
|
@ -81,7 +81,7 @@ typedef enum {
|
|||||||
|
|
||||||
static int testCompareXMLToArgvFiles(const char *xml,
|
static int testCompareXMLToArgvFiles(const char *xml,
|
||||||
const char *cmdline,
|
const char *cmdline,
|
||||||
qemuCapsPtr extraFlags,
|
virQEMUCapsPtr extraFlags,
|
||||||
const char *migrateFrom,
|
const char *migrateFrom,
|
||||||
int migrateFd,
|
int migrateFd,
|
||||||
virQemuXML2ArgvTestFlags flags)
|
virQemuXML2ArgvTestFlags flags)
|
||||||
@ -108,7 +108,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(extraFlags, QEMU_CAPS_DOMID))
|
if (virQEMUCapsGet(extraFlags, QEMU_CAPS_DOMID))
|
||||||
vmdef->id = 6;
|
vmdef->id = 6;
|
||||||
else
|
else
|
||||||
vmdef->id = -1;
|
vmdef->id = -1;
|
||||||
@ -118,7 +118,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
monitor_chr.data.nix.path = (char *)"/tmp/test-monitor";
|
monitor_chr.data.nix.path = (char *)"/tmp/test-monitor";
|
||||||
monitor_chr.data.nix.listen = true;
|
monitor_chr.data.nix.listen = true;
|
||||||
|
|
||||||
qemuCapsSetList(extraFlags,
|
virQEMUCapsSetList(extraFlags,
|
||||||
QEMU_CAPS_VNC_COLON,
|
QEMU_CAPS_VNC_COLON,
|
||||||
QEMU_CAPS_NO_REBOOT,
|
QEMU_CAPS_NO_REBOOT,
|
||||||
QEMU_CAPS_NO_ACPI,
|
QEMU_CAPS_NO_ACPI,
|
||||||
@ -131,7 +131,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(extraFlags, QEMU_CAPS_DEVICE)) {
|
if (virQEMUCapsGet(extraFlags, QEMU_CAPS_DEVICE)) {
|
||||||
if (qemuDomainAssignAddresses(vmdef, extraFlags, NULL)) {
|
if (qemuDomainAssignAddresses(vmdef, extraFlags, NULL)) {
|
||||||
if (flags & FLAG_EXPECT_ERROR)
|
if (flags & FLAG_EXPECT_ERROR)
|
||||||
goto ok;
|
goto ok;
|
||||||
@ -145,7 +145,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
|
|
||||||
if (vmdef->os.arch == VIR_ARCH_X86_64 ||
|
if (vmdef->os.arch == VIR_ARCH_X86_64 ||
|
||||||
vmdef->os.arch == VIR_ARCH_I686) {
|
vmdef->os.arch == VIR_ARCH_I686) {
|
||||||
qemuCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS);
|
virQEMUCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuAssignDeviceAliases(vmdef, extraFlags) < 0)
|
if (qemuAssignDeviceAliases(vmdef, extraFlags) < 0)
|
||||||
@ -207,7 +207,7 @@ out:
|
|||||||
|
|
||||||
struct testInfo {
|
struct testInfo {
|
||||||
const char *name;
|
const char *name;
|
||||||
qemuCapsPtr extraFlags;
|
virQEMUCapsPtr extraFlags;
|
||||||
const char *migrateFrom;
|
const char *migrateFrom;
|
||||||
int migrateFd;
|
int migrateFd;
|
||||||
unsigned int flags;
|
unsigned int flags;
|
||||||
@ -228,7 +228,7 @@ testCompareXMLToArgvHelper(const void *data)
|
|||||||
abs_srcdir, info->name) < 0)
|
abs_srcdir, info->name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuCapsGet(info->extraFlags, QEMU_CAPS_MONITOR_JSON))
|
if (virQEMUCapsGet(info->extraFlags, QEMU_CAPS_MONITOR_JSON))
|
||||||
flags |= FLAG_JSON;
|
flags |= FLAG_JSON;
|
||||||
|
|
||||||
result = testCompareXMLToArgvFiles(xml, args, info->extraFlags,
|
result = testCompareXMLToArgvFiles(xml, args, info->extraFlags,
|
||||||
@ -243,7 +243,7 @@ cleanup:
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
testAddCPUModels(qemuCapsPtr caps, bool skipLegacy)
|
testAddCPUModels(virQEMUCapsPtr caps, bool skipLegacy)
|
||||||
{
|
{
|
||||||
const char *newModels[] = {
|
const char *newModels[] = {
|
||||||
"Opteron_G3", "Opteron_G2", "Opteron_G1",
|
"Opteron_G3", "Opteron_G2", "Opteron_G1",
|
||||||
@ -257,13 +257,13 @@ testAddCPUModels(qemuCapsPtr caps, bool skipLegacy)
|
|||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
for (i = 0 ; i < ARRAY_CARDINALITY(newModels) ; i++) {
|
for (i = 0 ; i < ARRAY_CARDINALITY(newModels) ; i++) {
|
||||||
if (qemuCapsAddCPUDefinition(caps, newModels[i]) < 0)
|
if (virQEMUCapsAddCPUDefinition(caps, newModels[i]) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (skipLegacy)
|
if (skipLegacy)
|
||||||
return 0;
|
return 0;
|
||||||
for (i = 0 ; i < ARRAY_CARDINALITY(legacyModels) ; i++) {
|
for (i = 0 ; i < ARRAY_CARDINALITY(legacyModels) ; i++) {
|
||||||
if (qemuCapsAddCPUDefinition(caps, legacyModels[i]) < 0)
|
if (virQEMUCapsAddCPUDefinition(caps, legacyModels[i]) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -317,11 +317,11 @@ mymain(void)
|
|||||||
static struct testInfo info = { \
|
static struct testInfo info = { \
|
||||||
name, NULL, migrateFrom, migrateFd, (flags) \
|
name, NULL, migrateFrom, migrateFd, (flags) \
|
||||||
}; \
|
}; \
|
||||||
if (!(info.extraFlags = qemuCapsNew())) \
|
if (!(info.extraFlags = virQEMUCapsNew())) \
|
||||||
return EXIT_FAILURE; \
|
return EXIT_FAILURE; \
|
||||||
if (testAddCPUModels(info.extraFlags, skipLegacyCPUs) < 0) \
|
if (testAddCPUModels(info.extraFlags, skipLegacyCPUs) < 0) \
|
||||||
return EXIT_FAILURE; \
|
return EXIT_FAILURE; \
|
||||||
qemuCapsSetList(info.extraFlags, __VA_ARGS__, QEMU_CAPS_LAST); \
|
virQEMUCapsSetList(info.extraFlags, __VA_ARGS__, QEMU_CAPS_LAST);\
|
||||||
if (virtTestRun("QEMU XML-2-ARGV " name, \
|
if (virtTestRun("QEMU XML-2-ARGV " name, \
|
||||||
1, testCompareXMLToArgvHelper, &info) < 0) \
|
1, testCompareXMLToArgvHelper, &info) < 0) \
|
||||||
ret = -1; \
|
ret = -1; \
|
||||||
|
@ -25,7 +25,7 @@ static virQEMUDriver driver;
|
|||||||
|
|
||||||
static int testCompareXMLToArgvFiles(const char *xml,
|
static int testCompareXMLToArgvFiles(const char *xml,
|
||||||
const char *cmdline,
|
const char *cmdline,
|
||||||
qemuCapsPtr extraFlags,
|
virQEMUCapsPtr extraFlags,
|
||||||
const char *migrateFrom,
|
const char *migrateFrom,
|
||||||
int migrateFd,
|
int migrateFd,
|
||||||
bool json,
|
bool json,
|
||||||
@ -76,7 +76,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuCapsGet(extraFlags, QEMU_CAPS_DOMID))
|
if (virQEMUCapsGet(extraFlags, QEMU_CAPS_DOMID))
|
||||||
vmdef->id = 6;
|
vmdef->id = 6;
|
||||||
else
|
else
|
||||||
vmdef->id = -1;
|
vmdef->id = -1;
|
||||||
@ -86,13 +86,13 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
monitor_chr.data.nix.path = (char *)"/tmp/test-monitor";
|
monitor_chr.data.nix.path = (char *)"/tmp/test-monitor";
|
||||||
monitor_chr.data.nix.listen = true;
|
monitor_chr.data.nix.listen = true;
|
||||||
|
|
||||||
qemuCapsSetList(extraFlags,
|
virQEMUCapsSetList(extraFlags,
|
||||||
QEMU_CAPS_VNC_COLON,
|
QEMU_CAPS_VNC_COLON,
|
||||||
QEMU_CAPS_NO_REBOOT,
|
QEMU_CAPS_NO_REBOOT,
|
||||||
QEMU_CAPS_NO_ACPI,
|
QEMU_CAPS_NO_ACPI,
|
||||||
QEMU_CAPS_LAST);
|
QEMU_CAPS_LAST);
|
||||||
|
|
||||||
if (qemuCapsGet(extraFlags, QEMU_CAPS_DEVICE))
|
if (virQEMUCapsGet(extraFlags, QEMU_CAPS_DEVICE))
|
||||||
qemuDomainAssignAddresses(vmdef, extraFlags, NULL);
|
qemuDomainAssignAddresses(vmdef, extraFlags, NULL);
|
||||||
|
|
||||||
log = virtTestLogContentAndReset();
|
log = virtTestLogContentAndReset();
|
||||||
@ -101,7 +101,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
|
|
||||||
if (vmdef->os.arch == VIR_ARCH_X86_64 ||
|
if (vmdef->os.arch == VIR_ARCH_X86_64 ||
|
||||||
vmdef->os.arch == VIR_ARCH_I686) {
|
vmdef->os.arch == VIR_ARCH_I686) {
|
||||||
qemuCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS);
|
virQEMUCapsSet(extraFlags, QEMU_CAPS_PCI_MULTIBUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuAssignDeviceAliases(vmdef, extraFlags) < 0)
|
if (qemuAssignDeviceAliases(vmdef, extraFlags) < 0)
|
||||||
@ -157,7 +157,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
|
|
||||||
struct testInfo {
|
struct testInfo {
|
||||||
const char *name;
|
const char *name;
|
||||||
qemuCapsPtr extraFlags;
|
virQEMUCapsPtr extraFlags;
|
||||||
const char *migrateFrom;
|
const char *migrateFrom;
|
||||||
int migrateFd;
|
int migrateFd;
|
||||||
bool json;
|
bool json;
|
||||||
@ -215,9 +215,9 @@ mymain(void)
|
|||||||
struct testInfo info = { \
|
struct testInfo info = { \
|
||||||
name, NULL, migrateFrom, migrateFd, json, expectError \
|
name, NULL, migrateFrom, migrateFd, json, expectError \
|
||||||
}; \
|
}; \
|
||||||
if (!(info.extraFlags = qemuCapsNew())) \
|
if (!(info.extraFlags = virQEMUCapsNew())) \
|
||||||
return EXIT_FAILURE; \
|
return EXIT_FAILURE; \
|
||||||
qemuCapsSetList(info.extraFlags, __VA_ARGS__, QEMU_CAPS_LAST); \
|
virQEMUCapsSetList(info.extraFlags, __VA_ARGS__, QEMU_CAPS_LAST);\
|
||||||
if (virtTestRun("QEMU XML-2-ARGV " name, \
|
if (virtTestRun("QEMU XML-2-ARGV " name, \
|
||||||
1, testCompareXMLToArgvHelper, &info) < 0) \
|
1, testCompareXMLToArgvHelper, &info) < 0) \
|
||||||
ret = -1; \
|
ret = -1; \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user