libqos: use generic qtest_shutdown()

Machine specific shutdown function can be registered by
the machine specific qtest_XXX_boot() if needed.

So we will not have to test twice the architecture (on boot and on
shutdown) if the test can be run on several architectures.

Signed-off-by: Laurent Vivier <lvivier@redhat.com>
Reviewed-by: Greg Kurz <groug@kaod.org>
Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
Laurent Vivier 2016-09-29 12:32:46 +02:00 committed by David Gibson
parent 2ecd7e2f25
commit 61ae5cf3a2
5 changed files with 21 additions and 6 deletions

View File

@ -8,6 +8,7 @@ static QOSOps qos_ops = {
.uninit_allocator = pc_alloc_uninit, .uninit_allocator = pc_alloc_uninit,
.qpci_init = qpci_init_pc, .qpci_init = qpci_init_pc,
.qpci_free = qpci_free_pc, .qpci_free = qpci_free_pc,
.shutdown = qtest_pc_shutdown,
}; };
QOSState *qtest_pc_vboot(const char *cmdline_fmt, va_list ap) QOSState *qtest_pc_vboot(const char *cmdline_fmt, va_list ap)
@ -31,5 +32,5 @@ QOSState *qtest_pc_boot(const char *cmdline_fmt, ...)
void qtest_pc_shutdown(QOSState *qs) void qtest_pc_shutdown(QOSState *qs)
{ {
return qtest_shutdown(qs); return qtest_common_shutdown(qs);
} }

View File

@ -8,6 +8,7 @@ static QOSOps qos_ops = {
.uninit_allocator = spapr_alloc_uninit, .uninit_allocator = spapr_alloc_uninit,
.qpci_init = qpci_init_spapr, .qpci_init = qpci_init_spapr,
.qpci_free = qpci_free_spapr, .qpci_free = qpci_free_spapr,
.shutdown = qtest_spapr_shutdown,
}; };
QOSState *qtest_spapr_vboot(const char *cmdline_fmt, va_list ap) QOSState *qtest_spapr_vboot(const char *cmdline_fmt, va_list ap)
@ -29,5 +30,5 @@ QOSState *qtest_spapr_boot(const char *cmdline_fmt, ...)
void qtest_spapr_shutdown(QOSState *qs) void qtest_spapr_shutdown(QOSState *qs)
{ {
return qtest_shutdown(qs); return qtest_common_shutdown(qs);
} }

View File

@ -52,7 +52,7 @@ QOSState *qtest_boot(QOSOps *ops, const char *cmdline_fmt, ...)
/** /**
* Tear down the QEMU instance. * Tear down the QEMU instance.
*/ */
void qtest_shutdown(QOSState *qs) void qtest_common_shutdown(QOSState *qs)
{ {
if (qs->ops) { if (qs->ops) {
if (qs->pcibus && qs->ops->qpci_free) { if (qs->pcibus && qs->ops->qpci_free) {
@ -68,6 +68,15 @@ void qtest_shutdown(QOSState *qs)
g_free(qs); g_free(qs);
} }
void qtest_shutdown(QOSState *qs)
{
if (qs->ops && qs->ops->shutdown) {
qs->ops->shutdown(qs);
} else {
qtest_common_shutdown(qs);
}
}
void set_context(QOSState *s) void set_context(QOSState *s)
{ {
global_qtest = s->qts; global_qtest = s->qts;

View File

@ -5,22 +5,26 @@
#include "libqos/pci.h" #include "libqos/pci.h"
#include "libqos/malloc-pc.h" #include "libqos/malloc-pc.h"
typedef struct QOSState QOSState;
typedef struct QOSOps { typedef struct QOSOps {
QGuestAllocator *(*init_allocator)(QAllocOpts); QGuestAllocator *(*init_allocator)(QAllocOpts);
void (*uninit_allocator)(QGuestAllocator *); void (*uninit_allocator)(QGuestAllocator *);
QPCIBus *(*qpci_init)(QGuestAllocator *alloc); QPCIBus *(*qpci_init)(QGuestAllocator *alloc);
void (*qpci_free)(QPCIBus *bus); void (*qpci_free)(QPCIBus *bus);
void (*shutdown)(QOSState *);
} QOSOps; } QOSOps;
typedef struct QOSState { struct QOSState {
QTestState *qts; QTestState *qts;
QGuestAllocator *alloc; QGuestAllocator *alloc;
QPCIBus *pcibus; QPCIBus *pcibus;
QOSOps *ops; QOSOps *ops;
} QOSState; };
QOSState *qtest_vboot(QOSOps *ops, const char *cmdline_fmt, va_list ap); QOSState *qtest_vboot(QOSOps *ops, const char *cmdline_fmt, va_list ap);
QOSState *qtest_boot(QOSOps *ops, const char *cmdline_fmt, ...); QOSState *qtest_boot(QOSOps *ops, const char *cmdline_fmt, ...);
void qtest_common_shutdown(QOSState *qs);
void qtest_shutdown(QOSState *qs); void qtest_shutdown(QOSState *qs);
bool have_qemu_img(void); bool have_qemu_img(void);
void mkimg(const char *file, const char *fmt, unsigned size_mb); void mkimg(const char *file, const char *fmt, unsigned size_mb);

View File

@ -22,7 +22,7 @@ static void test_rtas_get_time_of_day(void)
t2 = mktimegm(&tm); t2 = mktimegm(&tm);
g_assert(t2 - t1 < 5); /* 5 sec max to run the test */ g_assert(t2 - t1 < 5); /* 5 sec max to run the test */
qtest_spapr_shutdown(qs); qtest_shutdown(qs);
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])