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>
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef LIBQOS_H
 | 
						|
#define LIBQOS_H
 | 
						|
 | 
						|
#include "libqtest.h"
 | 
						|
#include "libqos/pci.h"
 | 
						|
#include "libqos/malloc-pc.h"
 | 
						|
 | 
						|
typedef struct QOSState QOSState;
 | 
						|
 | 
						|
typedef struct QOSOps {
 | 
						|
    QGuestAllocator *(*init_allocator)(QAllocOpts);
 | 
						|
    void (*uninit_allocator)(QGuestAllocator *);
 | 
						|
    QPCIBus *(*qpci_init)(QGuestAllocator *alloc);
 | 
						|
    void (*qpci_free)(QPCIBus *bus);
 | 
						|
    void (*shutdown)(QOSState *);
 | 
						|
} QOSOps;
 | 
						|
 | 
						|
struct QOSState {
 | 
						|
    QTestState *qts;
 | 
						|
    QGuestAllocator *alloc;
 | 
						|
    QPCIBus *pcibus;
 | 
						|
    QOSOps *ops;
 | 
						|
};
 | 
						|
 | 
						|
QOSState *qtest_vboot(QOSOps *ops, const char *cmdline_fmt, va_list ap);
 | 
						|
QOSState *qtest_boot(QOSOps *ops, const char *cmdline_fmt, ...);
 | 
						|
void qtest_common_shutdown(QOSState *qs);
 | 
						|
void qtest_shutdown(QOSState *qs);
 | 
						|
bool have_qemu_img(void);
 | 
						|
void mkimg(const char *file, const char *fmt, unsigned size_mb);
 | 
						|
void mkqcow2(const char *file, unsigned size_mb);
 | 
						|
void set_context(QOSState *s);
 | 
						|
void migrate(QOSState *from, QOSState *to, const char *uri);
 | 
						|
void prepare_blkdebug_script(const char *debug_fn, const char *event);
 | 
						|
void generate_pattern(void *buffer, size_t len, size_t cycle_len);
 | 
						|
 | 
						|
static inline uint64_t qmalloc(QOSState *q, size_t bytes)
 | 
						|
{
 | 
						|
    return guest_alloc(q->alloc, bytes);
 | 
						|
}
 | 
						|
 | 
						|
static inline void qfree(QOSState *q, uint64_t addr)
 | 
						|
{
 | 
						|
    guest_free(q->alloc, addr);
 | 
						|
}
 | 
						|
 | 
						|
#endif
 |