root/sys/sys/memrange.h
/*
 * Memory range attribute operations, performed on /dev/mem
 */

#ifndef _SYS_MEMRANGE_H_
#define _SYS_MEMRANGE_H_

#include <sys/ioccom.h>

/* Memory range attributes */
#define MDF_UNCACHEABLE         (1<<0)  /* region not cached */
#define MDF_WRITECOMBINE        (1<<1)  /* region supports "write combine" action */
#define MDF_WRITETHROUGH        (1<<2)  /* write-through cached */
#define MDF_WRITEBACK           (1<<3)  /* write-back cached */
#define MDF_WRITEPROTECT        (1<<4)  /* read-only region */
#define MDF_UNKNOWN             (1<<5)  /* any state we don't understand */
#define MDF_ATTRMASK            (0x00ffffff)

#define MDF_FIXBASE             (1<<24) /* fixed base */
#define MDF_FIXLEN              (1<<25) /* fixed length */
#define MDF_FIRMWARE            (1<<26) /* set by firmware (XXX not useful?) */
#define MDF_ACTIVE              (1<<27) /* currently active */
#define MDF_BOGUS               (1<<28) /* we don't like it */
#define MDF_FIXACTIVE           (1<<29) /* can't be turned off */
#define MDF_BUSY                (1<<30) /* range is in use */
#define MDF_FORCE               (1<<31) /* force risky changes */

struct mem_range_desc
{
        u_int64_t       mr_base;
        u_int64_t       mr_len;
        int             mr_flags;
        char            mr_owner[8];
};

struct mem_range_op
{
        struct mem_range_desc   *mo_desc;
        int                     mo_arg[2];
#define MEMRANGE_SET_UPDATE     0
#define MEMRANGE_SET_REMOVE     1
        /* XXX want a flag that says "set and undo when I exit" */
};

#define MEMRANGE_GET    _IOWR('m', 50, struct mem_range_op)
#define MEMRANGE_SET    _IOW('m', 51, struct mem_range_op)

#define ME_STATE_INVALID        0
#define ME_STATE_VALID          1
#define ME_STATE_MAPPED         2

struct mem_extract {
        uint64_t        me_vaddr;
        uint64_t        me_paddr;
        int             me_domain;
        int             me_state;
        uint64_t        pad1[5];
};

#define MEM_EXTRACT_PADDR       _IOWR('m', 52, struct mem_extract)

struct mem_livedump_arg {
        int             fd;
        int             flags;
        uint8_t         compression;
        uint8_t         pad1[7];
        uint64_t        pad2[2];
};

#define MEM_KERNELDUMP  _IOW('m', 53, struct mem_livedump_arg)

#ifdef _KERNEL

MALLOC_DECLARE(M_MEMDESC);

struct mem_range_softc;
struct mem_range_ops
{
        void    (*init)(struct mem_range_softc *sc);
        int     (*set)(struct mem_range_softc *sc, struct mem_range_desc *mrd, int *arg);
        void    (*initAP)(struct mem_range_softc *sc);
        void    (*reinit)(struct mem_range_softc *sc);
};

struct mem_range_softc 
{
        struct mem_range_ops    *mr_op;
        int                     mr_cap;
        int                     mr_ndesc;
        struct mem_range_desc   *mr_desc;
};

extern struct mem_range_softc mem_range_softc;

extern void     mem_range_init(void);
extern void     mem_range_destroy(void);

extern int      mem_range_attr_get(struct mem_range_desc *mrd, int *arg);
extern int      mem_range_attr_set(struct mem_range_desc *mrd, int *arg);

#endif /* _KERNEL */

#endif /* _SYS_MEMRANGE_H_ */