All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jin Dongming <jin.dongming@np.css.fujitsu.com>
To: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: APEI-lenb <lenb@kernel.org>, Huang Ying <ying.huang@intel.com>,
	Andi Kleen <andi@firstfloor.org>,
	Randy Dunlap <randy.dunlap@oracle.com>,
	Stephen Rothwell <sfr@canb.auug.org.au>,
	Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>,
	ACPI <linux-acpi@vger.kernel.org>,
	LKLM <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 1/2] [Patch-next] ACPI, APEI Fix the return value(==NULL) of acpi_pre_map().
Date: Fri, 03 Sep 2010 17:37:22 +0900	[thread overview]
Message-ID: <4C80B3C2.7030500@np.css.fujitsu.com> (raw)
In-Reply-To: <201009020947.44090.bjorn.helgaas@hp.com>

Hi, Bjorn Helgaas

I will modify this patch and resend it as soon as possible in next week.

Best Regards,
Jin Dongming

(2010/09/03 0:47), Bjorn Helgaas wrote:
> On Thursday, September 02, 2010 01:20:18 am Jin Dongming wrote:
>> acpi_pre_map() is used for remapping the physical address of I/O, so
>> it should be return NULL or remapped virtual address. The problem is
>> that when (paddr - pg_off) equals 0, no matter whether I/O remapping is
>> successful or not, the function returns NULL.
>>
>> In acpi_pre_map(), after the physical address is remapped successfully,
>> it will check whether the physical address has been added into acpi_iomaps
>> list again.
>>    - If the physical address has been added into acpi_iomaps, the virtual
>>      address will be saved in vaddr.
>>    - Otherwise, NULL be saved in vaddr.
>>
>> So if the physical address is the first time to be remapped, vaddr will be
>> NULL always.
>>
>> In many cases, (paddr - pg_off) may not equal 0. So the function could work
>> well. In our machine, (paddr - pg_off) equals 0, so the return value of
>> acpi_pre_map() is NULL.
>>
>> This patch fixed it and I confirmed it on x86_64 next-tree.
> 
> This description is complicated and obscures the very simple bug
> you are fixing.  I suggest something like this:
> 
>   ACPI: fix acpi_pre_map() return value
> 
>   After we ioremap() a new region, we call __acpi_try_ioremap() to
>   see whether another thread has already mapped the same region.
>   This check clobbers "vaddr", so compute the return value using
>   the ioremap() result "map->vaddr" instead.
> 
>> v2:
>>     Modified the unsuitable description of patch.
>>
>> v3:
>>     Modified the wrong words in the description of patch.   
>>
>> Signed-off-by: Jin Dongming <jin.dongming@np.css.fujitsu.com>
>> Acked-by: Huang Ying <ying.huang@intel.com>
>> ---
>>  drivers/acpi/atomicio.c |    4 ++--
>>  1 files changed, 2 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/acpi/atomicio.c b/drivers/acpi/atomicio.c
>> index 8f8bd73..1bc2614 100644
>> --- a/drivers/acpi/atomicio.c
>> +++ b/drivers/acpi/atomicio.c
>> @@ -133,7 +133,7 @@ static void __iomem *acpi_pre_map(phys_addr_t paddr,
>>  
>>  	spin_lock_irqsave(&acpi_iomaps_lock, flags);
>>  	vaddr = __acpi_try_ioremap(paddr, size);
>> -	if (vaddr) {
>> +	if (unlikely(vaddr)) {
> 
> This "unlikely" addition also obscures things.  It's completely
> unrelated to the bug you're fixing, so it should be in a different
> patch, and I'm dubious that there's enough performance advantage to
> compensate for the decreased code readability.  I wouldn't make this
> change unless you can measure a performance improvement.
> 
>>  		spin_unlock_irqrestore(&acpi_iomaps_lock, flags);
>>  		iounmap(map->vaddr);
>>  		kfree(map);
>> @@ -142,7 +142,7 @@ static void __iomem *acpi_pre_map(phys_addr_t paddr,
>>  	list_add_tail_rcu(&map->list, &acpi_iomaps);
>>  	spin_unlock_irqrestore(&acpi_iomaps_lock, flags);
>>  
>> -	return vaddr + (paddr - pg_off);
>> +	return map->vaddr + (paddr - pg_off);
> 
> Since you're changing this line anyway, I think you should change it to:
> 
>   return map->vaddr + (paddr - map->paddr);
> 
> so it matches __acpi_try_ioremap().
> 
>>  err_unmap:
>>  	iounmap(vaddr);
>>  	return NULL;
>> -- 1.7.1.
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 
> 



      reply	other threads:[~2010-09-03  8:36 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-09-02  7:20 [PATCH 1/2] [Patch-next] ACPI, APEI Fix the return value(==NULL) of acpi_pre_map() Jin Dongming
2010-09-02 15:47 ` Bjorn Helgaas
2010-09-03  8:37   ` Jin Dongming [this message]

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=4C80B3C2.7030500@np.css.fujitsu.com \
    --to=jin.dongming@np.css.fujitsu.com \
    --cc=andi@firstfloor.org \
    --cc=bjorn.helgaas@hp.com \
    --cc=lenb@kernel.org \
    --cc=linux-acpi@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=randy.dunlap@oracle.com \
    --cc=seto.hidetoshi@jp.fujitsu.com \
    --cc=sfr@canb.auug.org.au \
    --cc=ying.huang@intel.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.