#ifndef _VMM_DRV_H_
#define _VMM_DRV_H_
#ifdef _KERNEL
#include <sys/file.h>
#include <sys/stdbool.h>
struct vmm_hold;
typedef struct vmm_hold vmm_hold_t;
struct vmm_lease;
typedef struct vmm_lease vmm_lease_t;
struct vmm_page;
typedef struct vmm_page vmm_page_t;
#define VMPF_DEFER_DIRTY (1 << 0)
typedef int (*vmm_drv_iop_cb_t)(void *, bool, uint16_t, uint8_t, uint32_t *);
typedef int (*vmm_drv_mmio_cb_t)(void *, bool, uint64_t, int, uint64_t *);
extern int vmm_drv_hold(file_t *, cred_t *, vmm_hold_t **);
extern void vmm_drv_rele(vmm_hold_t *);
extern boolean_t vmm_drv_release_reqd(vmm_hold_t *);
extern vmm_lease_t *vmm_drv_lease_sign(vmm_hold_t *, boolean_t (*)(void *),
void *);
extern void vmm_drv_lease_break(vmm_hold_t *, vmm_lease_t *);
extern boolean_t vmm_drv_lease_expired(vmm_lease_t *);
extern vmm_page_t *vmm_drv_page_hold(vmm_lease_t *, uintptr_t, int);
extern vmm_page_t *vmm_drv_page_hold_ext(vmm_lease_t *, uintptr_t, int, int);
extern void vmm_drv_page_release(vmm_page_t *);
extern void vmm_drv_page_release_chain(vmm_page_t *);
extern const void *vmm_drv_page_readable(const vmm_page_t *);
extern void *vmm_drv_page_writable(const vmm_page_t *);
extern void vmm_drv_page_mark_dirty(vmm_page_t *);
extern void vmm_drv_page_chain(vmm_page_t *, vmm_page_t *);
extern vmm_page_t *vmm_drv_page_next(const vmm_page_t *);
extern int vmm_drv_msi(vmm_lease_t *, uint64_t, uint64_t);
extern int vmm_drv_ioport_hook(vmm_hold_t *, uint16_t, vmm_drv_iop_cb_t, void *,
void **);
extern void vmm_drv_ioport_unhook(vmm_hold_t *, void **);
extern int vmm_drv_mmio_hook(vmm_hold_t *, uint64_t, uint32_t,
vmm_drv_mmio_cb_t, void *, void **);
extern int vmm_drv_mmio_unhook(vmm_hold_t *, void **);
#endif
#endif