|
@@ -210,8 +210,6 @@ static bool memory_region_ioeventfd_equal(MemoryRegionIoeventfd a,
|
|
|
&& !memory_region_ioeventfd_before(b, a);
|
|
|
}
|
|
|
|
|
|
-typedef struct FlatRange FlatRange;
|
|
|
-
|
|
|
/* Range of memory in the global map. Addresses are absolute. */
|
|
|
struct FlatRange {
|
|
|
MemoryRegion *mr;
|
|
@@ -222,19 +220,6 @@ struct FlatRange {
|
|
|
bool readonly;
|
|
|
};
|
|
|
|
|
|
-/* Flattened global view of current active memory hierarchy. Kept in sorted
|
|
|
- * order.
|
|
|
- */
|
|
|
-struct FlatView {
|
|
|
- struct rcu_head rcu;
|
|
|
- unsigned ref;
|
|
|
- FlatRange *ranges;
|
|
|
- unsigned nr;
|
|
|
- unsigned nr_allocated;
|
|
|
- struct AddressSpaceDispatch *dispatch;
|
|
|
- MemoryRegion *root;
|
|
|
-};
|
|
|
-
|
|
|
typedef struct AddressSpaceOps AddressSpaceOps;
|
|
|
|
|
|
#define FOR_EACH_FLAT_RANGE(var, view) \
|
|
@@ -322,21 +307,6 @@ static void flatview_unref(FlatView *view)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-FlatView *address_space_to_flatview(AddressSpace *as)
|
|
|
-{
|
|
|
- return atomic_rcu_read(&as->current_map);
|
|
|
-}
|
|
|
-
|
|
|
-AddressSpaceDispatch *flatview_to_dispatch(FlatView *fv)
|
|
|
-{
|
|
|
- return fv->dispatch;
|
|
|
-}
|
|
|
-
|
|
|
-AddressSpaceDispatch *address_space_to_dispatch(AddressSpace *as)
|
|
|
-{
|
|
|
- return flatview_to_dispatch(address_space_to_flatview(as));
|
|
|
-}
|
|
|
-
|
|
|
static bool can_merge(FlatRange *r1, FlatRange *r2)
|
|
|
{
|
|
|
return int128_eq(addrrange_end(r1->addr), r2->addr.start)
|