mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-25 10:57:29 +00:00 
			
		
		
		
	 c5b703ac20
			
		
	
	
		c5b703ac20
		
	
	
	
	
		
			
			Previously all callers had a containing object with a destructor that could be used to trigger cleanup of the IORange objects (typically just freeing the containing object), but a forthcoming memory API change doesn't fit this pattern. Rather than setting up a new global table, extend the ioport system to support destructors. Signed-off-by: Avi Kivity <avi@redhat.com>
		
			
				
	
	
		
			32 lines
		
	
	
		
			705 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			705 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef IORANGE_H
 | |
| #define IORANGE_H
 | |
| 
 | |
| #include <stdint.h>
 | |
| 
 | |
| typedef struct IORange IORange;
 | |
| typedef struct IORangeOps IORangeOps;
 | |
| 
 | |
| struct IORangeOps {
 | |
|     void (*read)(IORange *iorange, uint64_t offset, unsigned width,
 | |
|                  uint64_t *data);
 | |
|     void (*write)(IORange *iorange, uint64_t offset, unsigned width,
 | |
|                   uint64_t data);
 | |
|     void (*destructor)(IORange *iorange);
 | |
| };
 | |
| 
 | |
| struct IORange {
 | |
|     const IORangeOps *ops;
 | |
|     uint64_t base;
 | |
|     uint64_t len;
 | |
| };
 | |
| 
 | |
| static inline void iorange_init(IORange *iorange, const IORangeOps *ops,
 | |
|                                 uint64_t base, uint64_t len)
 | |
| {
 | |
|     iorange->ops = ops;
 | |
|     iorange->base = base;
 | |
|     iorange->len = len;
 | |
| }
 | |
| 
 | |
| #endif
 |