 085248ae87
			
		
	
	
		085248ae87
		
	
	
	
	
		
			
			libqos.c:
    -set_context for addressing which commands go where
    -migrate performs the actual migration
malloc.c:
    - Structure of the allocator is adjusted slightly with
      a second-tier malloc to make swapping around the allocators
      easy when we "migrate" the lists from the source to the destination.
Signed-off-by: John Snow <jsnow@redhat.com>
Reviewed-by: Kevin Wolf <kwolf@redhat.com>
Message-id: 1430417242-11859-4-git-send-email-jsnow@redhat.com
		
	
			
		
			
				
	
	
		
			39 lines
		
	
	
		
			1010 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1010 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __libqos_h
 | |
| #define __libqos_h
 | |
| 
 | |
| #include "libqtest.h"
 | |
| #include "libqos/pci.h"
 | |
| #include "libqos/malloc-pc.h"
 | |
| 
 | |
| typedef struct QOSOps {
 | |
|     QGuestAllocator *(*init_allocator)(QAllocOpts);
 | |
|     void (*uninit_allocator)(QGuestAllocator *);
 | |
| } QOSOps;
 | |
| 
 | |
| typedef struct QOSState {
 | |
|     QTestState *qts;
 | |
|     QGuestAllocator *alloc;
 | |
|     QOSOps *ops;
 | |
| } QOSState;
 | |
| 
 | |
| QOSState *qtest_vboot(QOSOps *ops, const char *cmdline_fmt, va_list ap);
 | |
| QOSState *qtest_boot(QOSOps *ops, const char *cmdline_fmt, ...);
 | |
| void qtest_shutdown(QOSState *qs);
 | |
| 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);
 | |
| 
 | |
| 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
 |