4 * Copyright Fujitsu, Corp. 2011, 2012
7 * Wen Congyang <wency@cn.fujitsu.com>
9 * This work is licensed under the terms of the GNU GPL, version 2 or later.
10 * See the COPYING file in the top-level directory.
14 #ifndef MEMORY_MAPPING_H
15 #define MEMORY_MAPPING_H
17 #include "qemu/queue.h"
18 #include "exec/memory.h"
20 typedef struct GuestPhysBlock
{
21 /* visible to guest, reflects PCI hole, etc */
27 /* points into host memory */
30 /* points to the MemoryRegion that this block belongs to */
33 QTAILQ_ENTRY(GuestPhysBlock
) next
;
36 /* point-in-time snapshot of guest-visible physical mappings */
37 typedef struct GuestPhysBlockList
{
39 QTAILQ_HEAD(GuestPhysBlockHead
, GuestPhysBlock
) head
;
42 /* The physical and virtual address in the memory mapping are contiguous. */
43 typedef struct MemoryMapping
{
45 target_ulong virt_addr
;
47 QTAILQ_ENTRY(MemoryMapping
) next
;
50 struct MemoryMappingList
{
52 MemoryMapping
*last_mapping
;
53 QTAILQ_HEAD(, MemoryMapping
) head
;
57 * add or merge the memory region [phys_addr, phys_addr + length) into the
58 * memory mapping's list. The region's virtual address starts with virt_addr,
59 * and is contiguous. The list is sorted by phys_addr.
61 void memory_mapping_list_add_merge_sorted(MemoryMappingList
*list
,
66 void memory_mapping_list_free(MemoryMappingList
*list
);
68 void memory_mapping_list_init(MemoryMappingList
*list
);
70 void guest_phys_blocks_free(GuestPhysBlockList
*list
);
71 void guest_phys_blocks_init(GuestPhysBlockList
*list
);
72 void guest_phys_blocks_append(GuestPhysBlockList
*list
);
74 void qemu_get_guest_memory_mapping(MemoryMappingList
*list
,
75 const GuestPhysBlockList
*guest_phys_blocks
,
78 /* get guest's memory mapping without do paging(virtual address is 0). */
79 void qemu_get_guest_simple_memory_mapping(MemoryMappingList
*list
,
80 const GuestPhysBlockList
*guest_phys_blocks
);
82 void memory_mapping_filter(MemoryMappingList
*list
, int64_t begin
,