From: Wanpeng Li <liwanp@linux.vnet.ibm.com>
To: Konrad Rzeszutek Wilk <konrad@darnok.org>
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: Sun, 17 Mar 2013 08:11:38 +0800 [thread overview]
Message-ID: <20130317001137.GB8297@hacker.(null)> (raw)
In-Reply-To: <20130316130302.GA5987@konrad-lan.dumpdata.com>
On Sat, Mar 16, 2013 at 09:03:04AM -0400, Konrad Rzeszutek Wilk wrote:
>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.
Great point! I will also clean it in zram implementation.
>> +
>> + 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);
To make sure kernel store is visiable to user space mappings of that 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>
next prev parent reply other threads:[~2013-03-17 0:11 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
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 [this message]
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='20130317001137.GB8297@hacker.(null)' \
--to=liwanp@linux.vnet.ibm.com \
--cc=akpm@linux-foundation.org \
--cc=dan.magenheimer@oracle.com \
--cc=gregkh@linuxfoundation.org \
--cc=konrad@darnok.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--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.