public inbox for kvm@vger.kernel.org
 help / color / mirror / Atom feed
From: Anthony Liguori <anthony@codemonkey.ws>
To: Cam Macdonell <cam@cs.ualberta.ca>
Cc: kvm-devel <kvm-devel@lists.sourceforge.net>
Subject: Re: Sharing a page of memory between the guest and host
Date: Wed, 05 Mar 2008 20:09:33 -0600	[thread overview]
Message-ID: <47CF525D.5010500@codemonkey.ws> (raw)
In-Reply-To: <47CF27B2.8080509@cs.ualberta.ca>

Cam Macdonell wrote:
> Hello,
>
> Is it possible to share a memory (a page perhaps) between the host and 
> guest?

Yes, the host always has access to all of the guests memory.  All of the 
virtio drivers depend on this fact.  With KVM, the userspace (in this 
case, QEMU), just tells the kernel about a virtual address region and 
the kernel uses that region of virtual memory for the guest's physical 
memory.  Whatever you (as userspace) maps into that region is totally up 
to you.

>   More precisely, could a host and guest share a memory-mapped 
> file?

It will be a lot easier once we have MMU notifiers upstream.  You'll be 
able to simply mmap(MAP_FIXED) a file into the guest's physical address 
space even while it's running.  For now, you have to setup these 
mappings before the VM starts.

>   If one were crazy enough to want to do this, where should they 
> look first?
>   

If you look at the -mem-file implementation in the latest git, you'll 
see that all the guest's memory can be an mmap()'d file.

Regards,

Anthony Liguori

> Thanks,
> Cam
>
> -------------------------------------------------------------------------
> This SF.net email is sponsored by: Microsoft
> Defy all challenges. Microsoft(R) Visual Studio 2008.
> http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
> _______________________________________________
> kvm-devel mailing list
> kvm-devel@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/kvm-devel
>   


-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/

  reply	other threads:[~2008-03-06  2:09 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-03-05 23:07 Sharing a page of memory between the guest and host Cam Macdonell
2008-03-06  2:09 ` Anthony Liguori [this message]
2008-03-06 16:13   ` Cam Macdonell
2008-03-12 23:36   ` Cam Macdonell

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=47CF525D.5010500@codemonkey.ws \
    --to=anthony@codemonkey.ws \
    --cc=cam@cs.ualberta.ca \
    --cc=kvm-devel@lists.sourceforge.net \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox