monitor/qmp: Update comment for commit 4eaca8de268
[qemu/armbru.git] / include / exec / memory-internal.h
blobef4fb9237127e4aee2e4a0bff9531f3feabcb4df
1 /*
2 * Declarations for functions which are internal to the memory subsystem.
4 * Copyright 2011 Red Hat, Inc. and/or its affiliates
6 * Authors:
7 * Avi Kivity <avi@redhat.com>
9 * This work is licensed under the terms of the GNU GPL, version 2 or
10 * later. See the COPYING file in the top-level directory.
15 * This header is for use by exec.c, memory.c and accel/tcg/cputlb.c ONLY,
16 * for declarations which are shared between the memory subsystem's
17 * internals and the TCG TLB code. Do not include it from elsewhere.
20 #ifndef MEMORY_INTERNAL_H
21 #define MEMORY_INTERNAL_H
23 #include "cpu.h"
25 #ifndef CONFIG_USER_ONLY
26 static inline AddressSpaceDispatch *flatview_to_dispatch(FlatView *fv)
28 return fv->dispatch;
31 static inline AddressSpaceDispatch *address_space_to_dispatch(AddressSpace *as)
33 return flatview_to_dispatch(address_space_to_flatview(as));
36 FlatView *address_space_get_flatview(AddressSpace *as);
37 void flatview_unref(FlatView *view);
39 extern const MemoryRegionOps unassigned_mem_ops;
41 bool memory_region_access_valid(MemoryRegion *mr, hwaddr addr,
42 unsigned size, bool is_write,
43 MemTxAttrs attrs);
45 void flatview_add_to_dispatch(FlatView *fv, MemoryRegionSection *section);
46 AddressSpaceDispatch *address_space_dispatch_new(FlatView *fv);
47 void address_space_dispatch_compact(AddressSpaceDispatch *d);
48 void address_space_dispatch_free(AddressSpaceDispatch *d);
50 void mtree_print_dispatch(struct AddressSpaceDispatch *d,
51 MemoryRegion *root);
53 struct page_collection;
55 /* Opaque struct for passing info from memory_notdirty_write_prepare()
56 * to memory_notdirty_write_complete(). Callers should treat all fields
57 * as private, with the exception of @active.
59 * @active is a field which is not touched by either the prepare or
60 * complete functions, but which the caller can use if it wishes to
61 * track whether it has called prepare for this struct and so needs
62 * to later call the complete function.
64 typedef struct {
65 CPUState *cpu;
66 struct page_collection *pages;
67 ram_addr_t ram_addr;
68 vaddr mem_vaddr;
69 unsigned size;
70 bool active;
71 } NotDirtyInfo;
73 /**
74 * memory_notdirty_write_prepare: call before writing to non-dirty memory
75 * @ndi: pointer to opaque NotDirtyInfo struct
76 * @cpu: CPU doing the write
77 * @mem_vaddr: virtual address of write
78 * @ram_addr: the ram address of the write
79 * @size: size of write in bytes
81 * Any code which writes to the host memory corresponding to
82 * guest RAM which has been marked as NOTDIRTY must wrap those
83 * writes in calls to memory_notdirty_write_prepare() and
84 * memory_notdirty_write_complete():
86 * NotDirtyInfo ndi;
87 * memory_notdirty_write_prepare(&ndi, ....);
88 * ... perform write here ...
89 * memory_notdirty_write_complete(&ndi);
91 * These calls will ensure that we flush any TCG translated code for
92 * the memory being written, update the dirty bits and (if possible)
93 * remove the slowpath callback for writing to the memory.
95 * This must only be called if we are using TCG; it will assert otherwise.
97 * We may take locks in the prepare call, so callers must ensure that
98 * they don't exit (via longjump or otherwise) without calling complete.
100 * This call must only be made inside an RCU critical section.
101 * (Note that while we're executing a TCG TB we're always in an
102 * RCU critical section, which is likely to be the case for callers
103 * of these functions.)
105 void memory_notdirty_write_prepare(NotDirtyInfo *ndi,
106 CPUState *cpu,
107 vaddr mem_vaddr,
108 ram_addr_t ram_addr,
109 unsigned size);
111 * memory_notdirty_write_complete: finish write to non-dirty memory
112 * @ndi: pointer to the opaque NotDirtyInfo struct which was initialized
113 * by memory_not_dirty_write_prepare().
115 void memory_notdirty_write_complete(NotDirtyInfo *ndi);
117 #endif
118 #endif