* Peter Xu ([email protected]) wrote:
> Also we change the 2nd parameter of it to be the relative offset
> within the memory region. This is to be used in follow up patches.
>
> Signed-off-by: Peter Xu <[email protected]>
> ---
> exec.c | 3 ++-
> include/exec/ram_addr.h | 2 +-
> memory.c | 3 +--
> 3 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/exec.c b/exec.c
> index 4e734770c2..2615b4cfed 100644
> --- a/exec.c
> +++ b/exec.c
> @@ -1387,9 +1387,10 @@ bool
> cpu_physical_memory_test_and_clear_dirty(ram_addr_t start,
> }
>
> DirtyBitmapSnapshot *cpu_physical_memory_snapshot_and_clear_dirty
> - (ram_addr_t start, ram_addr_t length, unsigned client)
> +(MemoryRegion *mr, hwaddr addr, hwaddr length, unsigned client)
Better to keep some indent?
> {
> DirtyMemoryBlocks *blocks;
> + ram_addr_t start = memory_region_get_ram_addr(mr) + addr;
> unsigned long align = 1UL << (TARGET_PAGE_BITS + BITS_PER_LEVEL);
> ram_addr_t first = QEMU_ALIGN_DOWN(start, align);
> ram_addr_t last = QEMU_ALIGN_UP(start + length, align);
> diff --git a/include/exec/ram_addr.h b/include/exec/ram_addr.h
> index 79e70a96ee..f8ee011d3c 100644
> --- a/include/exec/ram_addr.h
> +++ b/include/exec/ram_addr.h
> @@ -403,7 +403,7 @@ bool cpu_physical_memory_test_and_clear_dirty(ram_addr_t
> start,
> unsigned client);
>
> DirtyBitmapSnapshot *cpu_physical_memory_snapshot_and_clear_dirty
> - (ram_addr_t start, ram_addr_t length, unsigned client);
> +(MemoryRegion *mr, ram_addr_t start, hwaddr length, unsigned client);
You've called it 'start' there but 'addr' in the definition.
Either way a comment saying that it's the offset with mr would be good.
Dave
>
> bool cpu_physical_memory_snapshot_get_dirty(DirtyBitmapSnapshot *snap,
> ram_addr_t start,
> diff --git a/memory.c b/memory.c
> index cff0ea8f40..84bba7b65c 100644
> --- a/memory.c
> +++ b/memory.c
> @@ -2071,8 +2071,7 @@ DirtyBitmapSnapshot
> *memory_region_snapshot_and_clear_dirty(MemoryRegion *mr,
> {
> assert(mr->ram_block);
> memory_region_sync_dirty_bitmap(mr);
> - return cpu_physical_memory_snapshot_and_clear_dirty(
> - memory_region_get_ram_addr(mr) + addr, size, client);
> + return cpu_physical_memory_snapshot_and_clear_dirty(mr, addr, size,
> client);
> }
>
> bool memory_region_snapshot_get_dirty(MemoryRegion *mr, DirtyBitmapSnapshot
> *snap,
> --
> 2.17.1
>
--
Dr. David Alan Gilbert / [email protected] / Manchester, UK