public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Jerome Glisse <glisse@freedesktop.org>
To: "Pallipadi, Venkatesh" <venkatesh.pallipadi@intel.com>
Cc: "linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	suresh.b.siddha@intel.com
Subject: Re: PAT wc & vmap mapping count issue ?
Date: Thu, 30 Jul 2009 22:04:33 +0200	[thread overview]
Message-ID: <1248984273.2462.44.camel@localhost> (raw)
In-Reply-To: <20090730191757.GA16239@linux-os.sc.intel.com>

On Thu, 2009-07-30 at 12:17 -0700, Pallipadi, Venkatesh wrote:
> This seems to be a regression from changeset
> 3869c4aa18835c8c61b44bd0f3ace36e9d3b5bd0
> 
> Below test patch should fix the problem. Can you please try it and let use know.
> We can then send a cleaner patch with changelog etc to upstream+stable kernels.
> 
> Thanks,
> Venki
> 
> Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
> Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
> ---
>  arch/x86/mm/pageattr.c |    9 ++++++---
>  1 files changed, 6 insertions(+), 3 deletions(-)
> 
> diff --git a/arch/x86/mm/pageattr.c b/arch/x86/mm/pageattr.c
> index 1b734d7..895d90e 100644
> --- a/arch/x86/mm/pageattr.c
> +++ b/arch/x86/mm/pageattr.c
> @@ -997,12 +997,15 @@ EXPORT_SYMBOL(set_memory_array_uc);
>  int _set_memory_wc(unsigned long addr, int numpages)
>  {
>  	int ret;
> +	unsigned long addr_copy = addr;
> +
>  	ret = change_page_attr_set(&addr, numpages,
>  				    __pgprot(_PAGE_CACHE_UC_MINUS), 0);
> -
>  	if (!ret) {
> -		ret = change_page_attr_set(&addr, numpages,
> -				    __pgprot(_PAGE_CACHE_WC), 0);
> +		ret = change_page_attr_set_clr(&addr_copy, numpages,
> +					       __pgprot(_PAGE_CACHE_WC),
> +					       __pgprot(_PAGE_CACHE_MASK),
> +					       0, 0, NULL);
>  	}
>  	return ret;
>  }

Yes it fixes the issue for me (at least it seems, so far after bunch of
minutes no corruption despite massive set_wc/set_wb/free_page calls).
Thanks a lot for tracking this down.

Cheers,
Jerome Glisse


      reply	other threads:[~2009-07-30 20:05 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-07-30 11:11 PAT wc & vmap mapping count issue ? Jerome Glisse
2009-07-30 17:06 ` Jerome Glisse
2009-07-30 18:01   ` Pallipadi, Venkatesh
2009-07-30 18:48     ` Jerome Glisse
2009-07-30 19:17   ` Pallipadi, Venkatesh
2009-07-30 20:04     ` Jerome Glisse [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=1248984273.2462.44.camel@localhost \
    --to=glisse@freedesktop.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=suresh.b.siddha@intel.com \
    --cc=venkatesh.pallipadi@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox