Re: [PATCH v2 07/10] zram: optimize memory operations withclear_page()/copy_page()

From: Minchan Kim
Date: Wed Jun 05 2013 - 02:57:53 EST


Looks good but although we can know your intention easily with only
subject, it would be better to add body in description.

More questionable thing is I'm not sure Greg accepts this optimization
patch(NOT bug fix) because he claimed he will not accept any patches
from zram/zsmalloc except plain bug fix patch if we don't give any
plan about promotion from staging tree and we didn't yet.(Maybe I need
to talk about zsmalloc promotion with z* family people and mm guys)

If it could be acceptable, we have a few patches to optimize zram, too.

On Wed, Jun 05, 2013 at 12:06:05AM +0800, Jiang Liu wrote:
> Signed-off-by: Jiang Liu <jiang.liu@xxxxxxxxxx>
> ---
> drivers/staging/zram/zram_drv.c | 27 ++++++++++++++++-----------
> 1 file changed, 16 insertions(+), 11 deletions(-)
>
> diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c
> index 1c3974f..a4595ca 100644
> --- a/drivers/staging/zram/zram_drv.c
> +++ b/drivers/staging/zram/zram_drv.c
> @@ -128,23 +128,26 @@ static void zram_free_page(struct zram *zram, size_t index)
> meta->table[index].size = 0;
> }
>
> +static inline int is_partial_io(struct bio_vec *bvec)
> +{
> + return bvec->bv_len != PAGE_SIZE;
> +}
> +
> static void handle_zero_page(struct bio_vec *bvec)
> {
> struct page *page = bvec->bv_page;
> void *user_mem;
>
> user_mem = kmap_atomic(page);
> - memset(user_mem + bvec->bv_offset, 0, bvec->bv_len);
> + if (is_partial_io(bvec))
> + memset(user_mem + bvec->bv_offset, 0, bvec->bv_len);
> + else
> + clear_page(user_mem);
> kunmap_atomic(user_mem);
>
> flush_dcache_page(page);
> }
>
> -static inline int is_partial_io(struct bio_vec *bvec)
> -{
> - return bvec->bv_len != PAGE_SIZE;
> -}
> -
> static int zram_decompress_page(struct zram *zram, char *mem, u32 index)
> {
> int ret = LZO_E_OK;
> @@ -154,13 +157,13 @@ static int zram_decompress_page(struct zram *zram, char *mem, u32 index)
> unsigned long handle = meta->table[index].handle;
>
> if (!handle || zram_test_flag(meta, index, ZRAM_ZERO)) {
> - memset(mem, 0, PAGE_SIZE);
> + clear_page(mem);
> return 0;
> }
>
> cmem = zs_map_object(meta->mem_pool, handle, ZS_MM_RO);
> if (meta->table[index].size == PAGE_SIZE)
> - memcpy(mem, cmem, PAGE_SIZE);
> + copy_page(mem, cmem);
> else
> ret = lzo1x_decompress_safe(cmem, meta->table[index].size,
> mem, &clen);
> @@ -309,11 +312,13 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index,
> }
> cmem = zs_map_object(meta->mem_pool, handle, ZS_MM_WO);
>
> - if ((clen == PAGE_SIZE) && !is_partial_io(bvec))
> + if ((clen == PAGE_SIZE) && !is_partial_io(bvec)) {
> src = kmap_atomic(page);
> - memcpy(cmem, src, clen);
> - if ((clen == PAGE_SIZE) && !is_partial_io(bvec))
> + copy_page(cmem, src);
> kunmap_atomic(src);
> + } else {
> + memcpy(cmem, src, clen);
> + }
>
> zs_unmap_object(meta->mem_pool, handle);
>
> --
> 1.8.1.2
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/

--
Kind regards,
Minchan Kim
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/