]> Git Repo - qemu.git/blame - include/exec/memory-internal.h
Merge remote-tracking branch 'remotes/xtensa/tags/20190228-xtensa' into staging
[qemu.git] / include / exec / memory-internal.h
CommitLineData
67d95c15 1/*
9d70618c 2 * Declarations for functions which are internal to the memory subsystem.
67d95c15
AK
3 *
4 * Copyright 2011 Red Hat, Inc. and/or its affiliates
5 *
6 * Authors:
7 * Avi Kivity <[email protected]>
8 *
6b620ca3
PB
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.
67d95c15
AK
11 *
12 */
13
14/*
9d70618c
PM
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.
67d95c15
AK
18 */
19
7762c2c1
AK
20#ifndef MEMORY_INTERNAL_H
21#define MEMORY_INTERNAL_H
67d95c15
AK
22
23#ifndef CONFIG_USER_ONLY
785a507e
PB
24static inline AddressSpaceDispatch *flatview_to_dispatch(FlatView *fv)
25{
26 return fv->dispatch;
27}
28
29static inline AddressSpaceDispatch *address_space_to_dispatch(AddressSpace *as)
30{
31 return flatview_to_dispatch(address_space_to_flatview(as));
32}
ac1970fb 33
48564041
PB
34FlatView *address_space_get_flatview(AddressSpace *as);
35void flatview_unref(FlatView *view);
36
d197063f
PB
37extern const MemoryRegionOps unassigned_mem_ops;
38
d2702032 39bool memory_region_access_valid(MemoryRegion *mr, hwaddr addr,
6d7b9a6c
PM
40 unsigned size, bool is_write,
41 MemTxAttrs attrs);
d2702032 42
8629d3fc
AK
43void flatview_add_to_dispatch(FlatView *fv, MemoryRegionSection *section);
44AddressSpaceDispatch *address_space_dispatch_new(FlatView *fv);
45void address_space_dispatch_compact(AddressSpaceDispatch *d);
66a6df1d 46void address_space_dispatch_free(AddressSpaceDispatch *d);
9a62e24f 47
5e8fd947
AK
48void mtree_print_dispatch(fprintf_function mon, void *f,
49 struct AddressSpaceDispatch *d,
50 MemoryRegion *root);
51
0ac20318
EC
52struct page_collection;
53
27266271
PM
54/* Opaque struct for passing info from memory_notdirty_write_prepare()
55 * to memory_notdirty_write_complete(). Callers should treat all fields
56 * as private, with the exception of @active.
57 *
58 * @active is a field which is not touched by either the prepare or
59 * complete functions, but which the caller can use if it wishes to
60 * track whether it has called prepare for this struct and so needs
61 * to later call the complete function.
62 */
63typedef struct {
64 CPUState *cpu;
0ac20318 65 struct page_collection *pages;
27266271
PM
66 ram_addr_t ram_addr;
67 vaddr mem_vaddr;
68 unsigned size;
27266271
PM
69 bool active;
70} NotDirtyInfo;
71
72/**
73 * memory_notdirty_write_prepare: call before writing to non-dirty memory
74 * @ndi: pointer to opaque NotDirtyInfo struct
75 * @cpu: CPU doing the write
76 * @mem_vaddr: virtual address of write
77 * @ram_addr: the ram address of the write
78 * @size: size of write in bytes
79 *
80 * Any code which writes to the host memory corresponding to
81 * guest RAM which has been marked as NOTDIRTY must wrap those
82 * writes in calls to memory_notdirty_write_prepare() and
83 * memory_notdirty_write_complete():
84 *
85 * NotDirtyInfo ndi;
86 * memory_notdirty_write_prepare(&ndi, ....);
87 * ... perform write here ...
88 * memory_notdirty_write_complete(&ndi);
89 *
90 * These calls will ensure that we flush any TCG translated code for
91 * the memory being written, update the dirty bits and (if possible)
92 * remove the slowpath callback for writing to the memory.
93 *
94 * This must only be called if we are using TCG; it will assert otherwise.
95 *
0ac20318 96 * We may take locks in the prepare call, so callers must ensure that
27266271
PM
97 * they don't exit (via longjump or otherwise) without calling complete.
98 *
99 * This call must only be made inside an RCU critical section.
100 * (Note that while we're executing a TCG TB we're always in an
101 * RCU critical section, which is likely to be the case for callers
102 * of these functions.)
103 */
104void memory_notdirty_write_prepare(NotDirtyInfo *ndi,
105 CPUState *cpu,
106 vaddr mem_vaddr,
107 ram_addr_t ram_addr,
108 unsigned size);
109/**
110 * memory_notdirty_write_complete: finish write to non-dirty memory
111 * @ndi: pointer to the opaque NotDirtyInfo struct which was initialized
112 * by memory_not_dirty_write_prepare().
113 */
114void memory_notdirty_write_complete(NotDirtyInfo *ndi);
115
67d95c15 116#endif
67d95c15 117#endif
This page took 0.337326 seconds and 4 git commands to generate.