All of lore.kernel.org
 help / color / mirror / Atom feed
From: Igor Mammedov <imammedo@redhat.com>
To: Hu Tao <hutao@cn.fujitsu.com>
Cc: Yasunori Goto <y-goto@jp.fujitsu.com>,
	"Michael S. Tsirkin" <mst@redhat.com>,
	qemu-devel@nongnu.org, Eduardo Habkost <ehabkost@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>
Subject: Re: [Qemu-devel] [PATCH v4 20/29] hostmem: allow preallocation of any memory region
Date: Mon, 9 Jun 2014 14:28:23 +0200	[thread overview]
Message-ID: <20140609142823.5a822afa@thinkpad> (raw)
In-Reply-To: <d34cd2e6943f081d4b79df631797674bc9726fcd.1402299637.git.hutao@cn.fujitsu.com>

On Mon, 9 Jun 2014 18:25:25 +0800
Hu Tao <hutao@cn.fujitsu.com> wrote:

> From: Paolo Bonzini <pbonzini@redhat.com>
> 
> And allow preallocation of file-based memory even without -mem-prealloc.
> Some care is necessary because -mem-prealloc does not allow disabling
> preallocation for hostmem-file.
maybe 'prealloc' property should belong to hostmem-file instead of the
abstract hostmem.

> 
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
> Signed-off-by: Hu Tao <hutao@cn.fujitsu.com>
> ---
>  backends/hostmem-file.c  |  3 +++
>  backends/hostmem.c       | 42 ++++++++++++++++++++++++++++++++++++++++++
>  exec.c                   |  7 +++++++
>  include/exec/memory.h    | 10 ++++++++++
>  include/exec/ram_addr.h  |  1 +
>  include/sysemu/hostmem.h |  1 +
>  memory.c                 | 11 +++++++++++
>  7 files changed, 75 insertions(+)
> 
[...]

> @@ -165,6 +204,9 @@ host_memory_backend_memory_complete(UserCreatable *uc, Error **errp)
>          if (!backend->dump) {
>              qemu_madvise(ptr, sz, QEMU_MADV_DONTDUMP);
>          }
> +        if (backend->prealloc) {
> +            os_mem_prealloc(memory_region_get_fd(&backend->mr), ptr, sz);
> +        }
could it be done inside of hostmem_file->alloc()?

>      }
>  }
>  
> diff --git a/exec.c b/exec.c
> index 739f0cf..520d673 100644
> --- a/exec.c
> +++ b/exec.c
> @@ -1432,6 +1432,13 @@ void qemu_ram_remap(ram_addr_t addr, ram_addr_t length)
>  }
>  #endif /* !_WIN32 */
>  
> +int qemu_get_ram_fd(ram_addr_t addr)
> +{
> +    RAMBlock *block = qemu_get_ram_block(addr);
> +
> +    return block->fd;
> +}
> +
>  /* Return a host pointer to ram allocated with qemu_ram_alloc.
>     With the exception of the softmmu code in this file, this should
>     only be used for local memory (e.g. video ram) that the device owns,
> diff --git a/include/exec/memory.h b/include/exec/memory.h
> index 82d7781..36226f7 100644
> --- a/include/exec/memory.h
> +++ b/include/exec/memory.h
> @@ -534,6 +534,16 @@ bool memory_region_is_logging(MemoryRegion *mr);
>  bool memory_region_is_rom(MemoryRegion *mr);
>  
>  /**
> + * memory_region_get_fd: Get a file descriptor backing a RAM memory region.
> + *
> + * Returns a file descriptor backing a file-based RAM memory region,
> + * or -1 if the region is not a file-based RAM memory region.
> + *
> + * @mr: the RAM or alias memory region being queried.
> + */
> +int memory_region_get_fd(MemoryRegion *mr);
> +
> +/**
>   * memory_region_get_ram_ptr: Get a pointer into a RAM memory region.
>   *
>   * Returns a host pointer to a RAM memory region (created with
> diff --git a/include/exec/ram_addr.h b/include/exec/ram_addr.h
> index f9518a6..d352f60 100644
> --- a/include/exec/ram_addr.h
> +++ b/include/exec/ram_addr.h
> @@ -27,6 +27,7 @@ ram_addr_t qemu_ram_alloc_from_file(ram_addr_t size, MemoryRegion *mr,
>  ram_addr_t qemu_ram_alloc_from_ptr(ram_addr_t size, void *host,
>                                     MemoryRegion *mr);
>  ram_addr_t qemu_ram_alloc(ram_addr_t size, MemoryRegion *mr);
> +int qemu_get_ram_fd(ram_addr_t addr);
>  void *qemu_get_ram_ptr(ram_addr_t addr);
>  void qemu_ram_free(ram_addr_t addr);
>  void qemu_ram_free_from_ptr(ram_addr_t addr);
> diff --git a/include/sysemu/hostmem.h b/include/sysemu/hostmem.h
> index ede5ec9..4cae673 100644
> --- a/include/sysemu/hostmem.h
> +++ b/include/sysemu/hostmem.h
> @@ -53,6 +53,7 @@ struct HostMemoryBackend {
>      /* protected */
>      uint64_t size;
>      bool merge, dump;
> +    bool prealloc, force_prealloc;
>  
>      MemoryRegion mr;
>  };
> diff --git a/memory.c b/memory.c
> index 310729a..bcef72b 100644
> --- a/memory.c
> +++ b/memory.c
> @@ -1258,6 +1258,17 @@ void memory_region_reset_dirty(MemoryRegion *mr, hwaddr addr,
>      cpu_physical_memory_reset_dirty(mr->ram_addr + addr, size, client);
>  }
>  
> +int memory_region_get_fd(MemoryRegion *mr)
> +{
> +    if (mr->alias) {
> +        return memory_region_get_fd(mr->alias);
> +    }
> +
> +    assert(mr->terminates);
> +
> +    return qemu_get_ram_fd(mr->ram_addr & TARGET_PAGE_MASK);
> +}
> +
>  void *memory_region_get_ram_ptr(MemoryRegion *mr)
>  {
>      if (mr->alias) {
> -- 
> 1.9.3
> 
> 


-- 
Regards,
  Igor

  reply	other threads:[~2014-06-09 12:28 UTC|newest]

Thread overview: 92+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-06-09 10:25 [Qemu-devel] [PATCH v4 00/29] NUMA series and hostmem improvements Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 01/29] NUMA: move numa related code to new file numa.c Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 02/29] NUMA: check if the total numa memory size is equal to ram_size Hu Tao
2014-06-09 23:02   ` Eric Blake
2014-06-10  2:29     ` Hu Tao
2014-06-10  2:36       ` Eric Blake
2014-06-10  2:52         ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 03/29] NUMA: Add numa_info structure to contain numa nodes info Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 04/29] NUMA: convert -numa option to use OptsVisitor Hu Tao
2014-06-16 14:08   ` Eduardo Habkost
2014-06-16 14:16     ` Paolo Bonzini
2014-06-16 14:23       ` [Qemu-devel] [libvirt] " Eric Blake
2014-06-16 14:32         ` Paolo Bonzini
2014-06-16 15:39           ` Eduardo Habkost
2014-06-16 15:46             ` Paolo Bonzini
2014-06-16 16:05               ` Eric Blake
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 05/29] NUMA: expand MAX_NODES from 64 to 128 Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 06/29] man: improve -numa doc Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 07/29] vl: redo -object parsing Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 08/29] qmp: improve error reporting for -object and object-add Hu Tao
2014-06-09 15:57   ` Igor Mammedov
2014-06-10  2:07     ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 09/29] pc: pass MachineState to pc_memory_init Hu Tao
2014-06-09 13:14   ` Igor Mammedov
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 10/29] numa: introduce memory_region_allocate_system_memory Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 11/29] hostmem: separate allocation from UserCreatable complete method Hu Tao
2014-06-09 10:47   ` Igor Mammedov
2014-06-10  1:55     ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 12/29] numa: add -numa node,memdev= option Hu Tao
2014-06-09 17:22   ` [Qemu-devel] [PATCH v4 12/29] numa: add -numa node, memdev= option Eric Blake
2014-06-10  2:23     ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 13/29] memory: reorganize file-based allocation Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 14/29] memory: move mem_path handling to memory_region_allocate_system_memory Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 15/29] memory: add error propagation to file-based RAM allocation Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 16/29] memory: move preallocation code out of exec.c Hu Tao
2014-06-18 19:14   ` Michael S. Tsirkin
2014-06-19  0:43     ` Hu Tao
2014-06-20  3:26     ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 17/29] memory: move RAM_PREALLOC_MASK to exec.c, rename Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 18/29] hostmem: add file-based HostMemoryBackend Hu Tao
2014-06-09 11:32   ` Igor Mammedov
2014-06-09 11:35     ` Michael S. Tsirkin
2014-06-09 12:06       ` Igor Mammedov
2014-06-10  2:00     ` Hu Tao
2014-06-10  5:09       ` Paolo Bonzini
2014-06-10  8:30         ` Hu Tao
2014-06-10  8:56           ` Paolo Bonzini
2014-06-10  9:21             ` Hu Tao
2014-06-10  9:59             ` Michael S. Tsirkin
2014-06-10 11:12               ` Paolo Bonzini
2014-06-10 11:23                 ` Michael S. Tsirkin
2014-06-10 11:29                   ` Paolo Bonzini
2014-06-10 11:35                     ` Michael S. Tsirkin
2014-06-10 11:43                       ` Paolo Bonzini
2014-06-10 11:48                         ` Michael S. Tsirkin
2014-06-10 11:51                           ` Paolo Bonzini
2014-06-10  9:07           ` Igor Mammedov
2014-06-10  9:54             ` Michael S. Tsirkin
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 19/29] hostmem: add merge and dump properties Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 20/29] hostmem: allow preallocation of any memory region Hu Tao
2014-06-09 12:28   ` Igor Mammedov [this message]
2014-06-09 12:32     ` Paolo Bonzini
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 21/29] hostmem: add property to map memory with MAP_SHARED Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 22/29] configure: add Linux libnuma detection Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 23/29] hostmem: add properties for NUMA memory policy Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 24/29] Introduce signed range Hu Tao
2014-06-09 10:42   ` Peter Maydell
2014-06-09 10:59     ` Michael S. Tsirkin
2014-06-10  6:51       ` Hu Tao
2014-06-10  9:50         ` Michael S. Tsirkin
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 25/29] qapi: make string input visitor parse int list Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 26/29] qapi: make string output " Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 27/29] qom: introduce object_property_get_enum and object_property_get_uint16List Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 28/29] qmp: add query-memdev Hu Tao
2014-06-09 12:36   ` Igor Mammedov
2014-06-09 12:58     ` Paolo Bonzini
2014-06-09 13:32       ` Igor Mammedov
2014-06-09 13:40         ` Paolo Bonzini
2014-06-09 14:08           ` Igor Mammedov
2014-06-09 17:15           ` Eric Blake
2014-06-09 17:24   ` Eric Blake
2014-06-10  2:25     ` Hu Tao
2014-06-09 10:25 ` [Qemu-devel] [PATCH v4 29/29] hmp: add info memdev Hu Tao
2014-06-09 10:30 ` [Qemu-devel] [PATCH v4 00/29] NUMA series and hostmem improvements Michael S. Tsirkin
2014-06-09 11:40   ` Michael S. Tsirkin
2014-06-10  1:55     ` Hu Tao
2014-06-10  9:51     ` Hu Tao
2014-06-10  9:56       ` Michael S. Tsirkin
2014-06-10  9:57         ` Hu Tao
2014-06-10 10:19         ` Hu Tao
2014-06-10 10:27           ` Michael S. Tsirkin
2014-06-10 11:09             ` Hu Tao

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20140609142823.5a822afa@thinkpad \
    --to=imammedo@redhat.com \
    --cc=ehabkost@redhat.com \
    --cc=hutao@cn.fujitsu.com \
    --cc=mst@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=y-goto@jp.fujitsu.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.