2014-10-29 07:48:29 +01:00
|
|
|
/******************************************************************************
|
|
|
|
* memory.h
|
2019-09-19 14:05:00 +02:00
|
|
|
*
|
2014-10-29 07:48:29 +01:00
|
|
|
* Memory reservation and information.
|
2019-09-19 14:05:00 +02:00
|
|
|
*
|
2019-04-10 13:55:19 +02:00
|
|
|
* SPDX-License-Identifier: MIT
|
2014-10-29 07:48:29 +01:00
|
|
|
*
|
|
|
|
* Copyright (c) 2005, Keir Fraser <keir@xensource.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __XEN_PUBLIC_MEMORY_H__
|
|
|
|
#define __XEN_PUBLIC_MEMORY_H__
|
|
|
|
|
|
|
|
#include "xen.h"
|
|
|
|
|
|
|
|
/* Source mapping space. */
|
|
|
|
/* ` enum phys_map_space { */
|
|
|
|
#define XENMAPSPACE_shared_info 0 /* shared info page */
|
|
|
|
#define XENMAPSPACE_grant_table 1 /* grant table page */
|
|
|
|
#define XENMAPSPACE_gmfn 2 /* GMFN */
|
|
|
|
#define XENMAPSPACE_gmfn_range 3 /* GMFN range, XENMEM_add_to_physmap only. */
|
|
|
|
#define XENMAPSPACE_gmfn_foreign 4 /* GMFN from another dom,
|
|
|
|
* XENMEM_add_to_physmap_batch only. */
|
|
|
|
/* ` } */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Sets the GPFN at which a particular page appears in the specified guest's
|
|
|
|
* pseudophysical address space.
|
|
|
|
* arg == addr of xen_add_to_physmap_t.
|
|
|
|
*/
|
|
|
|
#define XENMEM_add_to_physmap 7
|
|
|
|
struct xen_add_to_physmap {
|
|
|
|
/* Which domain to change the mapping for. */
|
|
|
|
domid_t domid;
|
|
|
|
|
|
|
|
/* Number of pages to go through for gmfn_range */
|
|
|
|
UINT16 size;
|
|
|
|
|
|
|
|
UINT32 space; /* => enum phys_map_space */
|
|
|
|
|
|
|
|
#define XENMAPIDX_grant_table_status 0x80000000
|
|
|
|
|
|
|
|
/* Index into space being mapped. */
|
|
|
|
xen_ulong_t idx;
|
|
|
|
|
|
|
|
/* GPFN in domid where the source mapping page should appear. */
|
|
|
|
xen_pfn_t gpfn;
|
|
|
|
};
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2014-10-29 07:48:29 +01:00
|
|
|
typedef struct xen_add_to_physmap xen_add_to_physmap_t;
|
|
|
|
DEFINE_XEN_GUEST_HANDLE (xen_add_to_physmap_t);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Unmaps the page appearing at a particular GPFN from the specified guest's
|
|
|
|
* pseudophysical address space.
|
|
|
|
* arg == addr of xen_remove_from_physmap_t.
|
|
|
|
*/
|
|
|
|
#define XENMEM_remove_from_physmap 15
|
|
|
|
struct xen_remove_from_physmap {
|
|
|
|
/* Which domain to change the mapping for. */
|
|
|
|
domid_t domid;
|
|
|
|
|
|
|
|
/* GPFN of the current mapping of the page. */
|
|
|
|
xen_pfn_t gpfn;
|
|
|
|
};
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2014-10-29 07:48:29 +01:00
|
|
|
typedef struct xen_remove_from_physmap xen_remove_from_physmap_t;
|
|
|
|
DEFINE_XEN_GUEST_HANDLE (xen_remove_from_physmap_t);
|
|
|
|
|
2019-08-13 13:31:05 +02:00
|
|
|
/*
|
|
|
|
* Returns the pseudo-physical memory map as it was when the domain
|
|
|
|
* was started (specified by XENMEM_set_memory_map).
|
|
|
|
* arg == addr of xen_memory_map_t.
|
|
|
|
*/
|
|
|
|
#define XENMEM_memory_map 9
|
|
|
|
struct xen_memory_map {
|
|
|
|
/*
|
|
|
|
* On call the number of entries which can be stored in buffer. On
|
|
|
|
* return the number of entries which have been stored in
|
|
|
|
* buffer.
|
|
|
|
*/
|
|
|
|
UINT32 nr_entries;
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2019-08-13 13:31:05 +02:00
|
|
|
/*
|
|
|
|
* Entries in the buffer are in the same format as returned by the
|
|
|
|
* BIOS INT 0x15 EAX=0xE820 call.
|
|
|
|
*/
|
|
|
|
XEN_GUEST_HANDLE (void) buffer;
|
|
|
|
};
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2019-08-13 13:31:05 +02:00
|
|
|
typedef struct xen_memory_map xen_memory_map_t;
|
|
|
|
DEFINE_XEN_GUEST_HANDLE (xen_memory_map_t);
|
|
|
|
|
2014-10-29 07:48:29 +01:00
|
|
|
#endif /* __XEN_PUBLIC_MEMORY_H__ */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local variables:
|
|
|
|
* mode: C
|
|
|
|
* c-file-style: "BSD"
|
|
|
|
* c-basic-offset: 4
|
|
|
|
* tab-width: 4
|
|
|
|
* indent-tabs-mode: nil
|
|
|
|
* End:
|
|
|
|
*/
|