From: Huang Ying <ying.huang@intel.com>
To: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: "lenb@kernel.org" <lenb@kernel.org>,
ACPI Devel Maling List <linux-acpi@vger.kernel.org>,
Andi Kleen <ak@linux.intel.com>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATH 1/5 -v2] acpi, IO memory pre-mapping and atomic accessing
Date: Thu, 17 Dec 2009 16:33:07 +0800 [thread overview]
Message-ID: <1261038787.13378.148.camel@yhuang-dev.sh.intel.com> (raw)
In-Reply-To: <200912161054.19951.bjorn.helgaas@hp.com>
On Thu, 2009-12-17 at 01:54 +0800, Bjorn Helgaas wrote:
> On Tuesday 15 December 2009 06:23:15 pm Huang Ying wrote:
> > On Wed, 2009-12-16 at 01:47 +0800, Bjorn Helgaas wrote:
> > > On Monday 14 December 2009 06:04:13 pm Huang Ying wrote:
> > > > On Sat, 2009-12-12 at 01:36 +0800, Bjorn Helgaas wrote:
> > > > > I think your code would be simpler if acpi_pre_map_gar() returned a
> > > > > struct acpi_iomap pointer (from the caller's point of view, this would
> > > > > be an opaque cookie). Then you could just supply that cookie to
> > > > > acpi_atomic_write(), and you wouldn't have to look it up again. Maybe
> > > > > you could even get rid of the list and all the fancy RCU & kref stuff
> > > > > then, too.
> > > >
> > > > The interface chosen is based on usage model, which is:
> > > >
> > > > 1. In init function, all GARs needed are pre-mapped
> > > > 2. In atomic context, pre-mapped GARs are accessed
> > > > 3. In exit function, all GARs are post-unmapped
> > > >
> > > > In 3), if struct acpi_iomap* is used as parameter for post-unmap
> > > > function, we need to record that pointer in another list. In 2), we need
> > > > find mapped address from GAR.
> > >
> > > I understand that my proposal would require a slight change in your
> > > usage model. I am suggesting that you make it follow the same pattern
> > > as pci_iomap(), e.g.:
> > >
> > > void *pci_iomap(struct pci_dev *, int bar, unsigned long len);
> > > unsigned int ioread32(void *);
> > > void pci_iounmap(struct pci_dev *, void *);
> > >
> > > void *acpi_map_generic_address(struct acpi_generic_address *);
> > > u64 acpi_read_atomic(void *);
> > > void acpi_unmap_generic_address(void *);
> > >
> > > acpi_map_generic_address() would validate the GAR and do the ioremap().
> > > If the validation or ioremap() failed, it would return a NULL pointer.
> > >
> > > This would require the caller of acpi_map_generic_address() to hang onto
> > > the pointer returned (just as callers of pci_iomap() must hang onto the
> > > pointer it returns).
> > >
> > > The pointer would be supplied to acpi_read_atomic(), so it would not
> > > need to do acpi_check_gar() because we know it was done successfully
> > > in acpi_map_generic_address(). It wouldn't need to look up the GAR
> > > in the list because the list entry was passed in. Since all the
> > > possible failure conditions were checked in acpi_map_generic_address(),
> > > acpi_read_atomic() doesn't need to return status and could simply
> > > return the u64 directly.
> >
> > The usage model is different. Please take a look at
> > __apei_exec_read_register(). We need to get virtual address from
> > physical address in GAR. And many small-size GARs in ERST or EINJ may
> > share same page, so some kind of virtual space optimization is
> > necessary.
>
> The sharing could be done with a reference count in the map/unmap
> path.
>
> I don't have time to fully understand your patch series, but I suspect
> the issue is that you're interpreting opcodes, and those contain or
> reference generic_address structures, and you think it's easier just
> pass around the GAR pointer than it is to remember a (GAR, mapped-GAR)
> association made by pre_map_gar() and use the mapped-GAR when executing
> the "read" opcode.
So we need the (GAR, mapped-GAR) association anyway. Variable
acpi_iomaps in atomicio.c is such a association. When executing the
"read" opcode, we still need get mapped-GAR from the GAR. So I think
your proposal and my implementation is similar, with different naming
convention and you want to put the association in APEI code, and I want
to put it in ACPI code.
Best Regards,
Huang Ying
next prev parent reply other threads:[~2009-12-17 8:33 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-12-10 7:16 [PATH 1/5 -v2] acpi, IO memory pre-mapping and atomic accessing Huang Ying
2009-12-11 17:36 ` Bjorn Helgaas
2009-12-15 1:04 ` Huang Ying
2009-12-15 17:47 ` Bjorn Helgaas
2009-12-16 1:23 ` Huang Ying
2009-12-16 17:54 ` Bjorn Helgaas
2009-12-17 8:33 ` Huang Ying [this message]
2009-12-17 17:06 ` Bjorn Helgaas
2009-12-18 13:42 ` Thomas Renninger
2009-12-16 5:38 ` Len Brown
2009-12-16 5:40 ` Huang Ying
2009-12-18 18:11 ` Pavel Machek
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=1261038787.13378.148.camel@yhuang-dev.sh.intel.com \
--to=ying.huang@intel.com \
--cc=ak@linux.intel.com \
--cc=bjorn.helgaas@hp.com \
--cc=lenb@kernel.org \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-kernel@vger.kernel.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