From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932515AbdDQBsx (ORCPT ); Sun, 16 Apr 2017 21:48:53 -0400 Received: from mail-pg0-f66.google.com ([74.125.83.66]:36727 "EHLO mail-pg0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932128AbdDQBsv (ORCPT ); Sun, 16 Apr 2017 21:48:51 -0400 Date: Mon, 17 Apr 2017 10:48:53 +0900 From: Sergey Senozhatsky To: Minchan Kim Cc: Andrew Morton , linux-kernel@vger.kernel.org, Sergey Senozhatsky , kernel-team@lge.com, stable@vger.kernel.org Subject: Re: [PATCH 2/3] zram: do not use copy_page with non-page alinged address Message-ID: <20170417014853.GD518@jagdpanzerIV.localdomain> References: <1492042622-12074-1-git-send-email-minchan@kernel.org> <1492042622-12074-2-git-send-email-minchan@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1492042622-12074-2-git-send-email-minchan@kernel.org> User-Agent: Mutt/1.8.1 (2017-04-11) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On (04/13/17 09:17), Minchan Kim wrote: > The copy_page is optimized memcpy for page-alinged address. > If it is used with non-page aligned address, it can corrupt memory which > means system corruption. With zram, it can happen with > > 1. 64K architecture > 2. partial IO > 3. slub debug > > Partial IO need to allocate a page and zram allocates it via kmalloc. > With slub debug, kmalloc(PAGE_SIZE) doesn't return page-size aligned > address. And finally, copy_page(mem, cmem) corrupts memory. > > So, this patch changes it to memcpy. > > Acutaully, we don't need to change zram_bvec_write part because zsmalloc > returns page-aligned address in case of PAGE_SIZE class but it's not > good to rely on the internal of zsmalloc. > > Note: > When this patch is merged to stable, clear_page should be fixed, too. > Unfortunately, recent zram removes it by "same page merge" feature > so it's hard to backport this patch to -stable tree. > > I will handle it when I receive the mail from stable tree maintainer > to merge this patch to backport. > > Fixes: 42e99bd ("zram: optimize memory operations with clear_page()/copy_page()") > Cc: stable@vger.kernel.org > Signed-off-by: Minchan Kim Reviewed-by: Sergey Senozhatsky -ss