[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [RFC PATCH RDMA support v4: 04/10] iterators for gettin
From: |
Paolo Bonzini |
Subject: |
Re: [Qemu-devel] [RFC PATCH RDMA support v4: 04/10] iterators for getting the RAMBlocks |
Date: |
Mon, 18 Mar 2013 09:48:38 +0100 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/20130219 Thunderbird/17.0.3 |
Il 18/03/2013 04:18, address@hidden ha scritto:
> From: "Michael R. Hines" <address@hidden>
>
> This introduces:
> 1. qemu_ram_foreach_block
> 2. qemu_ram_count_blocks
>
> Both used in communicating the RAMBlocks
> to each side for later memory registration.
>
> Signed-off-by: Michael R. Hines <address@hidden>
> ---
> exec.c | 21 +++++++++++++++++++++
> include/exec/cpu-common.h | 6 ++++++
> 2 files changed, 27 insertions(+)
>
> diff --git a/exec.c b/exec.c
> index 8a6aac3..a985da8 100644
> --- a/exec.c
> +++ b/exec.c
> @@ -2629,3 +2629,24 @@ bool cpu_physical_memory_is_io(hwaddr phys_addr)
> memory_region_is_romd(section->mr));
> }
> #endif
> +
> +void qemu_ram_foreach_block(RAMBlockIterFunc func, void *opaque)
> +{
> + RAMBlock *block;
> +
> + QTAILQ_FOREACH(block, &ram_list.blocks, next) {
> + func(block->host, block->offset, block->length, opaque);
> + }
> +}
> +
> +int qemu_ram_count_blocks(void)
> +{
> + RAMBlock *block;
> + int total = 0;
> +
> + QTAILQ_FOREACH(block, &ram_list.blocks, next) {
> + total++;
> + }
Please move this to rdma.c, and implement it using qemu_ram_foreach_block.
Otherwise looks good.
Paolo
> + return total;
> +}
> diff --git a/include/exec/cpu-common.h b/include/exec/cpu-common.h
> index 2e5f11f..aea3fe0 100644
> --- a/include/exec/cpu-common.h
> +++ b/include/exec/cpu-common.h
> @@ -119,6 +119,12 @@ extern struct MemoryRegion io_mem_rom;
> extern struct MemoryRegion io_mem_unassigned;
> extern struct MemoryRegion io_mem_notdirty;
>
> +typedef void (RAMBlockIterFunc)(void *host_addr,
> + ram_addr_t offset, ram_addr_t length, void *opaque);
> +
> +void qemu_ram_foreach_block(RAMBlockIterFunc func, void *opaque);
> +int qemu_ram_count_blocks(void);
> +
> #endif
>
> #endif /* !CPU_COMMON_H */
>
- Re: [Qemu-devel] [RFC PATCH RDMA support v4: 07/10] connection-establishment for RDMA, (continued)
[Qemu-devel] [RFC PATCH RDMA support v4: 02/10] check for CONFIG_RDMA, mrhines, 2013/03/17
[Qemu-devel] [RFC PATCH RDMA support v4: 10/10] send pc.ram over RDMA, mrhines, 2013/03/17
[Qemu-devel] [RFC PATCH RDMA support v4: 04/10] iterators for getting the RAMBlocks, mrhines, 2013/03/17
- Re: [Qemu-devel] [RFC PATCH RDMA support v4: 04/10] iterators for getting the RAMBlocks,
Paolo Bonzini <=
[Qemu-devel] [RFC PATCH RDMA support v4: 09/10] check for QMP string and bypass nonblock() calls, mrhines, 2013/03/17
[Qemu-devel] [RFC PATCH RDMA support v4: 03/10] more verbose documentation of the RDMA transport, mrhines, 2013/03/17