From: Avi Kivity <avi@redhat.com>
To: "Michael S. Tsirkin" <mst@redhat.com>
Cc: qemu-devel@nongnu.org, kvm@vger.kernel.org
Subject: Re: [Qemu-devel] [RFC v2 01/20] Hierarchical memory region API
Date: Tue, 28 Jun 2011 14:51:27 +0300 [thread overview]
Message-ID: <4E09C03F.4070205@redhat.com> (raw)
In-Reply-To: <20110628100343.GA21866@redhat.com>
On 06/28/2011 01:03 PM, Michael S. Tsirkin wrote:
> On Mon, Jun 27, 2011 at 04:21:48PM +0300, Avi Kivity wrote:
>
> ...
>
> > +static bool memory_region_access_valid(MemoryRegion *mr,
> > + target_phys_addr_t addr,
> > + unsigned size)
> > +{
> > + if (!mr->ops->valid.unaligned&& (addr& (size - 1))) {
> > + return false;
> > + }
> > +
> > + /* Treat zero as compatibility all valid */
> > + if (!mr->ops->valid.max_access_size) {
> > + return true;
> > + }
> > +
> > + if (size> mr->ops->valid.max_access_size
> > + || size< mr->ops->valid.min_access_size) {
> > + return false;
> > + }
> > + return true;
> > +}
> > +
> > +static uint32_t memory_region_read_thunk_n(void *_mr,
> > + target_phys_addr_t addr,
> > + unsigned size)
> > +{
> > + MemoryRegion *mr = _mr;
> > + unsigned access_size, access_size_min, access_size_max;
> > + uint64_t access_mask;
> > + uint32_t data = 0, tmp;
> > + unsigned i;
> > +
> > + if (!memory_region_access_valid(mr, addr, size)) {
> > + return -1U; /* FIXME: better signalling */
> > + }
> > +
> > + /* FIXME: support unaligned access */
> > +
> > + access_size_min = mr->ops->impl.max_access_size;
>
> min = max: Intentional? Cut&paste error?
Bug; thanks.
> > diff --git a/memory.h b/memory.h
> > new file mode 100644
> > index 0000000..a67ff94
> > --- /dev/null
> > +++ b/memory.h
> > @@ -0,0 +1,201 @@
> > +#ifndef MEMORY_H
> > +#define MEMORY_H
> > +
> > +#ifndef CONFIG_USER_ONLY
>
> What's the story with this ifdef?
> There are no stubs provided ...
No callers either - I build with a full configuration. I prefer the
#ifdef here rather than all call sites.
> > +
> > +struct MemoryRegion {
> > + /* All fields are private - violators will be prosecuted */
> > + const MemoryRegionOps *ops;
> > + MemoryRegion *parent;
> > + uint64_t size;
> > + target_phys_addr_t addr;
> > + target_phys_addr_t offset;
> > + ram_addr_t ram_addr;
> > + bool has_ram_addr;
> > + MemoryRegion *alias;
> > + target_phys_addr_t alias_offset;
> > + unsigned priority;
> > + bool may_overlap;
> > + QTAILQ_HEAD(subregions, MemoryRegion) subregions;
> > + QTAILQ_ENTRY(MemoryRegion) subregions_link;
> > + QTAILQ_HEAD(coalesced_ranges, CoalescedMemoryRange) coalesced;
> > + const char *name;
>
> I'm never completely sure whether these should be target addresses
> or bus addresses or just uint64_t.
> With pci on a 32 bit system you can stick a 64 bit address
> in a BAR and the result will be that it is never accessed
> from the CPU.
>
I agree. Anyone objects to making the memory API 64-bit?
It will reduce performance slightly for 32-on-32, but these
configurations are getting rarer, and the performance loss is quite small.
Maybe we should make t_p_a_t 64-bit unconditionally. Note that sizes
have to be 64-bit in any case, otherwise you can't express a 4G range
without tricks.
--
error compiling committee.c: too many arguments to function
next prev parent reply other threads:[~2011-06-28 11:51 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-06-27 13:21 [Qemu-devel] [RFC v2 00/20] Memory API Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 01/20] Hierarchical memory region API Avi Kivity
2011-06-28 10:03 ` Michael S. Tsirkin
2011-06-28 10:28 ` Jan Kiszka
2011-06-28 11:53 ` Avi Kivity
2011-06-28 12:07 ` Jan Kiszka
2011-06-28 12:09 ` Avi Kivity
2011-06-28 12:46 ` Jan Kiszka
2011-06-28 12:53 ` Avi Kivity
2011-06-28 13:25 ` Peter Maydell
2011-06-28 13:36 ` Avi Kivity
2011-06-28 16:27 ` Olivier Galibert
2011-06-28 11:51 ` Avi Kivity [this message]
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 02/20] memory: implement dirty tracking Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 03/20] memory: merge adjacent segments of a single memory region Avi Kivity
2011-06-27 13:56 ` Jan Kiszka
2011-06-27 14:11 ` Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 04/20] Internal interfaces for memory API Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 05/20] exec.c: initialize memory map Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 06/20] pc: grab system_memory Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 07/20] pc: convert pc_memory_init() to memory API Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 08/20] pc: move global memory map out of pc_init1() and into its callers Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 09/20] pci: pass address space to pci bus when created Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 10/20] pci: add MemoryRegion based BAR management API Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 11/20] sysbus: add MemoryRegion based memory " Avi Kivity
2011-06-27 13:21 ` [Qemu-devel] [RFC v2 12/20] usb-ohci: convert to MemoryRegion Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 13/20] pci: add API to get a BAR's mapped address Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 14/20] vmsvga: don't remember pci BAR address in callback any more Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 15/20] vga: convert vga and its derivatives to the memory API Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 16/20] cirrus: simplify mmio BAR access functions Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 17/20] cirrus: simplify bitblt " Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 18/20] cirrus: simplify vga window mmio " Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 19/20] vga: " Avi Kivity
2011-06-27 13:22 ` [Qemu-devel] [RFC v2 20/20] cirrus: simplify linear framebuffer " Avi Kivity
2011-06-27 15:13 ` [Qemu-devel] [RFC v2 00/20] Memory API Avi Kivity
2011-06-27 15:52 ` Michael S. Tsirkin
2011-06-27 15:54 ` Avi Kivity
2011-06-27 15:59 ` Michael S. Tsirkin
2011-06-27 16:10 ` Avi Kivity
2011-06-27 20:28 ` Anthony Liguori
2011-06-27 15:37 ` Anthony Liguori
2011-06-27 15:44 ` Avi Kivity
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=4E09C03F.4070205@redhat.com \
--to=avi@redhat.com \
--cc=kvm@vger.kernel.org \
--cc=mst@redhat.com \
--cc=qemu-devel@nongnu.org \
/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;
as well as URLs for NNTP newsgroup(s).