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:
Daniel P. Berrangé 2019-11-26 16:53:53 +00:00
parent a7ef72a8fd
commit 74fb858f7d
6 changed files with 47 additions and 15 deletions

View File

@ -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)

View File

@ -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

View File

@ -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) {

View File

@ -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,

View File

@ -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;
} }

View File

@ -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)