mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 11:35:19 +00:00
conf: drop virCapsPtr param from basic post parse callback
The QEMU impl of the callback can directly use the QEMU capabilities cache to resolve the emulator binary name, allowing virCapsPtr to be dropped. Reviewed-by: Michal Privoznik <mprivozn@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
a7ef72a8fd
commit
74fb858f7d
@ -5832,7 +5832,7 @@ virDomainDefPostParse(virDomainDefPtr def,
|
|||||||
|
|
||||||
/* call the basic post parse callback */
|
/* call the basic post parse callback */
|
||||||
if (xmlopt->config.domainPostParseBasicCallback) {
|
if (xmlopt->config.domainPostParseBasicCallback) {
|
||||||
ret = xmlopt->config.domainPostParseBasicCallback(def, caps,
|
ret = xmlopt->config.domainPostParseBasicCallback(def,
|
||||||
xmlopt->config.priv);
|
xmlopt->config.priv);
|
||||||
|
|
||||||
if (virDomainDefPostParseCheckFailure(def, parseFlags, ret) < 0)
|
if (virDomainDefPostParseCheckFailure(def, parseFlags, ret) < 0)
|
||||||
|
@ -2627,7 +2627,6 @@ typedef enum {
|
|||||||
* parseOpaque is used. This callback is run prior to
|
* parseOpaque is used. This callback is run prior to
|
||||||
* virDomainDefPostParseCallback. */
|
* virDomainDefPostParseCallback. */
|
||||||
typedef int (*virDomainDefPostParseBasicCallback)(virDomainDefPtr def,
|
typedef int (*virDomainDefPostParseBasicCallback)(virDomainDefPtr def,
|
||||||
virCapsPtr caps,
|
|
||||||
void *opaque);
|
void *opaque);
|
||||||
|
|
||||||
/* Called once after everything else has been parsed, for adjusting
|
/* Called once after everything else has been parsed, for adjusting
|
||||||
|
@ -799,6 +799,26 @@ virQEMUCapsFindBinaryForArch(virArch hostarch,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
char *
|
||||||
|
virQEMUCapsGetDefaultEmulator(virArch hostarch,
|
||||||
|
virArch guestarch)
|
||||||
|
{
|
||||||
|
char *binary = NULL;
|
||||||
|
/* Check for existence of base emulator, or alternate base
|
||||||
|
* which can be used with magic cpu choice
|
||||||
|
*/
|
||||||
|
binary = virQEMUCapsFindBinaryForArch(hostarch, guestarch);
|
||||||
|
|
||||||
|
/* RHEL doesn't follow the usual naming for QEMU binaries and ships
|
||||||
|
* a single binary named qemu-kvm outside of $PATH instead */
|
||||||
|
if (virQEMUCapsGuestIsNative(hostarch, guestarch) && !binary)
|
||||||
|
binary = g_strdup("/usr/libexec/qemu-kvm");
|
||||||
|
|
||||||
|
return binary;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
virQEMUCapsInitGuest(virCapsPtr caps,
|
virQEMUCapsInitGuest(virCapsPtr caps,
|
||||||
virFileCachePtr cache,
|
virFileCachePtr cache,
|
||||||
@ -809,15 +829,7 @@ virQEMUCapsInitGuest(virCapsPtr caps,
|
|||||||
virQEMUCapsPtr qemuCaps = NULL;
|
virQEMUCapsPtr qemuCaps = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
/* Check for existence of base emulator, or alternate base
|
binary = virQEMUCapsGetDefaultEmulator(hostarch, guestarch);
|
||||||
* which can be used with magic cpu choice
|
|
||||||
*/
|
|
||||||
binary = virQEMUCapsFindBinaryForArch(hostarch, guestarch);
|
|
||||||
|
|
||||||
/* RHEL doesn't follow the usual naming for QEMU binaries and ships
|
|
||||||
* a single binary named qemu-kvm outside of $PATH instead */
|
|
||||||
if (virQEMUCapsGuestIsNative(hostarch, guestarch) && !binary)
|
|
||||||
binary = g_strdup("/usr/libexec/qemu-kvm");
|
|
||||||
|
|
||||||
/* Ignore binary if extracting version info fails */
|
/* Ignore binary if extracting version info fails */
|
||||||
if (binary) {
|
if (binary) {
|
||||||
|
@ -627,6 +627,8 @@ const char *virQEMUCapsGetMachineDefaultCPU(virQEMUCapsPtr qemuCaps,
|
|||||||
void virQEMUCapsFilterByMachineType(virQEMUCapsPtr qemuCaps,
|
void virQEMUCapsFilterByMachineType(virQEMUCapsPtr qemuCaps,
|
||||||
virDomainVirtType virtType,
|
virDomainVirtType virtType,
|
||||||
const char *machineType);
|
const char *machineType);
|
||||||
|
char * virQEMUCapsGetDefaultEmulator(virArch hostarch,
|
||||||
|
virArch guestarch);
|
||||||
|
|
||||||
virFileCachePtr virQEMUCapsCacheNew(const char *libDir,
|
virFileCachePtr virQEMUCapsCacheNew(const char *libDir,
|
||||||
const char *cacheDir,
|
const char *cacheDir,
|
||||||
|
@ -4677,13 +4677,16 @@ qemuDomainDefTsegPostParse(virDomainDefPtr def,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
qemuDomainDefPostParseBasic(virDomainDefPtr def,
|
qemuDomainDefPostParseBasic(virDomainDefPtr def,
|
||||||
virCapsPtr caps,
|
|
||||||
void *opaque G_GNUC_UNUSED)
|
void *opaque G_GNUC_UNUSED)
|
||||||
{
|
{
|
||||||
|
virQEMUDriverPtr driver = opaque;
|
||||||
|
|
||||||
/* check for emulator and create a default one if needed */
|
/* check for emulator and create a default one if needed */
|
||||||
if (!def->emulator &&
|
if (!def->emulator) {
|
||||||
!(def->emulator = virDomainDefGetDefaultEmulator(def, caps)))
|
if (!(def->emulator = virQEMUCapsGetDefaultEmulator(
|
||||||
|
driver->hostarch, def->os.arch)))
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -93,6 +93,22 @@ static const char *const *kvm_machines[VIR_ARCH_LAST] = {
|
|||||||
[VIR_ARCH_S390X] = s390x_machines,
|
[VIR_ARCH_S390X] = s390x_machines,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
char *
|
||||||
|
virFindFileInPath(const char *file)
|
||||||
|
{
|
||||||
|
if (g_str_has_prefix(file, "qemu-system") ||
|
||||||
|
g_str_equal(file, "qemu-kvm")) {
|
||||||
|
return g_strdup_printf("/usr/bin/%s", file);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Nothing in tests should be relying on real files
|
||||||
|
* in host OS, so we return NULL to try to force
|
||||||
|
* an error in such a case
|
||||||
|
*/
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
testQemuAddGuest(virCapsPtr caps,
|
testQemuAddGuest(virCapsPtr caps,
|
||||||
virArch arch)
|
virArch arch)
|
||||||
|
Loading…
Reference in New Issue
Block a user