From: Konrad Rzeszutek Wilk <konrad@darnok.org>
To: Wanpeng Li <liwanp@linux.vnet.ibm.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Andrew Morton <akpm@linux-foundation.org>,
Dan Magenheimer <dan.magenheimer@oracle.com>,
Seth Jennings <sjenning@linux.vnet.ibm.com>,
Minchan Kim <minchan@kernel.org>,
linux-mm@kvack.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 1/4] introduce zero filled pages handler
Date: Sat, 16 Mar 2013 09:03:04 -0400 [thread overview]
Message-ID: <20130316130302.GA5987@konrad-lan.dumpdata.com> (raw)
In-Reply-To: <1363255697-19674-2-git-send-email-liwanp@linux.vnet.ibm.com>
On Thu, Mar 14, 2013 at 06:08:14PM +0800, Wanpeng Li wrote:
> Introduce zero-filled pages handler to capture and handle zero pages.
>
> Acked-by: Dan Magenheimer <dan.magenheimer@oracle.com>
> Signed-off-by: Wanpeng Li <liwanp@linux.vnet.ibm.com>
> ---
> drivers/staging/zcache/zcache-main.c | 26 ++++++++++++++++++++++++++
> 1 files changed, 26 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/staging/zcache/zcache-main.c b/drivers/staging/zcache/zcache-main.c
> index 328898e..b71e033 100644
> --- a/drivers/staging/zcache/zcache-main.c
> +++ b/drivers/staging/zcache/zcache-main.c
> @@ -460,6 +460,32 @@ static void zcache_obj_free(struct tmem_obj *obj, struct tmem_pool *pool)
> kmem_cache_free(zcache_obj_cache, obj);
> }
>
> +static bool page_zero_filled(void *ptr)
Shouldn't this be 'struct page *p' ?
> +{
> + unsigned int pos;
> + unsigned long *page;
> +
> + page = (unsigned long *)ptr;
That way you can avoid this casting.
> +
> + for (pos = 0; pos < PAGE_SIZE / sizeof(*page); pos++) {
> + if (page[pos])
> + return false;
Perhaps allocate a static page filled with zeros and just do memcmp?
> + }
> +
> + return true;
> +}
> +
> +static void handle_zero_page(void *page)
> +{
> + void *user_mem;
> +
> + user_mem = kmap_atomic(page);
> + memset(user_mem, 0, PAGE_SIZE);
> + kunmap_atomic(user_mem);
> +
> + flush_dcache_page(page);
This is new. Could you kindly explain why it is needed? Thanks.
> +}
> +
> static struct tmem_hostops zcache_hostops = {
> .obj_alloc = zcache_obj_alloc,
> .obj_free = zcache_obj_free,
> --
> 1.7.7.6
>
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
WARNING: multiple messages have this Message-ID (diff)
From: Konrad Rzeszutek Wilk <konrad@darnok.org>
To: Wanpeng Li <liwanp@linux.vnet.ibm.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Andrew Morton <akpm@linux-foundation.org>,
Dan Magenheimer <dan.magenheimer@oracle.com>,
Seth Jennings <sjenning@linux.vnet.ibm.com>,
Minchan Kim <minchan@kernel.org>,
linux-mm@kvack.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 1/4] introduce zero filled pages handler
Date: Sat, 16 Mar 2013 09:03:04 -0400 [thread overview]
Message-ID: <20130316130302.GA5987@konrad-lan.dumpdata.com> (raw)
In-Reply-To: <1363255697-19674-2-git-send-email-liwanp@linux.vnet.ibm.com>
On Thu, Mar 14, 2013 at 06:08:14PM +0800, Wanpeng Li wrote:
> Introduce zero-filled pages handler to capture and handle zero pages.
>
> Acked-by: Dan Magenheimer <dan.magenheimer@oracle.com>
> Signed-off-by: Wanpeng Li <liwanp@linux.vnet.ibm.com>
> ---
> drivers/staging/zcache/zcache-main.c | 26 ++++++++++++++++++++++++++
> 1 files changed, 26 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/staging/zcache/zcache-main.c b/drivers/staging/zcache/zcache-main.c
> index 328898e..b71e033 100644
> --- a/drivers/staging/zcache/zcache-main.c
> +++ b/drivers/staging/zcache/zcache-main.c
> @@ -460,6 +460,32 @@ static void zcache_obj_free(struct tmem_obj *obj, struct tmem_pool *pool)
> kmem_cache_free(zcache_obj_cache, obj);
> }
>
> +static bool page_zero_filled(void *ptr)
Shouldn't this be 'struct page *p' ?
> +{
> + unsigned int pos;
> + unsigned long *page;
> +
> + page = (unsigned long *)ptr;
That way you can avoid this casting.
> +
> + for (pos = 0; pos < PAGE_SIZE / sizeof(*page); pos++) {
> + if (page[pos])
> + return false;
Perhaps allocate a static page filled with zeros and just do memcmp?
> + }
> +
> + return true;
> +}
> +
> +static void handle_zero_page(void *page)
> +{
> + void *user_mem;
> +
> + user_mem = kmap_atomic(page);
> + memset(user_mem, 0, PAGE_SIZE);
> + kunmap_atomic(user_mem);
> +
> + flush_dcache_page(page);
This is new. Could you kindly explain why it is needed? Thanks.
> +}
> +
> static struct tmem_hostops zcache_hostops = {
> .obj_alloc = zcache_obj_alloc,
> .obj_free = zcache_obj_free,
> --
> 1.7.7.6
>
next prev parent reply other threads:[~2013-03-16 13:03 UTC|newest]
Thread overview: 34+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-03-14 10:08 [PATCH v2 0/4] zcache: Support zero-filled pages more efficiently Wanpeng Li
2013-03-14 10:08 ` Wanpeng Li
2013-03-14 10:08 ` [PATCH v2 1/4] introduce zero filled pages handler Wanpeng Li
2013-03-14 10:08 ` Wanpeng Li
2013-03-16 13:03 ` Konrad Rzeszutek Wilk [this message]
2013-03-16 13:03 ` Konrad Rzeszutek Wilk
2013-03-16 18:24 ` Dan Magenheimer
2013-03-16 18:24 ` Dan Magenheimer
2013-03-19 16:44 ` Konrad Rzeszutek Wilk
2013-03-19 16:44 ` Konrad Rzeszutek Wilk
2013-03-25 19:07 ` Dan Magenheimer
2013-03-25 19:07 ` Dan Magenheimer
2013-03-17 0:11 ` Wanpeng Li
2013-03-17 0:11 ` Wanpeng Li
2013-03-14 10:08 ` [PATCH v2 2/4] zero-filled pages awareness Wanpeng Li
2013-03-14 10:08 ` Wanpeng Li
2013-03-16 13:07 ` Konrad Rzeszutek Wilk
2013-03-16 13:07 ` Konrad Rzeszutek Wilk
2013-03-14 10:08 ` [PATCH v2 3/4] introduce zero-filled page stat count Wanpeng Li
2013-03-14 10:08 ` Wanpeng Li
2013-03-16 13:06 ` Konrad Rzeszutek Wilk
2013-03-16 13:06 ` Konrad Rzeszutek Wilk
2013-03-17 0:13 ` Wanpeng Li
2013-03-17 0:13 ` Wanpeng Li
2013-03-17 12:58 ` Ric Mason
2013-03-17 12:58 ` Ric Mason
2013-03-19 16:41 ` Konrad Rzeszutek Wilk
2013-03-19 16:41 ` Konrad Rzeszutek Wilk
2013-03-19 23:31 ` Ric Mason
2013-03-19 23:31 ` Ric Mason
2013-03-20 10:22 ` Wanpeng Li
2013-03-20 10:22 ` Wanpeng Li
2013-03-14 10:08 ` [PATCH v2 4/4] clean TODO list Wanpeng Li
2013-03-14 10:08 ` Wanpeng Li
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=20130316130302.GA5987@konrad-lan.dumpdata.com \
--to=konrad@darnok.org \
--cc=akpm@linux-foundation.org \
--cc=dan.magenheimer@oracle.com \
--cc=gregkh@linuxfoundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=liwanp@linux.vnet.ibm.com \
--cc=minchan@kernel.org \
--cc=sjenning@linux.vnet.ibm.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.