mirror of
https://github.com/qemu/qemu.git
synced 2024-12-18 17:53:40 +08:00
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
|