* [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write @ 2013-01-28 0:38 Minchan Kim 2013-01-28 7:16 ` Pekka Enberg 2013-01-30 4:20 ` Greg Kroah-Hartman 0 siblings, 2 replies; 11+ messages in thread From: Minchan Kim @ 2013-01-28 0:38 UTC (permalink / raw) To: Greg Kroah-Hartman Cc: linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, Pekka Enberg, Minchan Kim, stable, Jerome Marchand Now zram allocates new page with GFP_KERNEL in zram I/O path if IO is partial. Unfortunately, It may cuase deadlock with reclaim path so this patch solves the problem. Cc: stable@vger.kernel.org Cc: Jerome Marchand <jmarchan@redhat.com> Acked-by: Nitin Gupta <ngupta@vflare.org> Signed-off-by: Minchan Kim <minchan@kernel.org> --- drivers/staging/zram/zram_drv.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c index 61fb8f1..b285b3a 100644 --- a/drivers/staging/zram/zram_drv.c +++ b/drivers/staging/zram/zram_drv.c @@ -220,7 +220,7 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, user_mem = kmap_atomic(page); if (is_partial_io(bvec)) /* Use a temporary buffer to decompress the page */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); + uncmem = kmalloc(PAGE_SIZE, GFP_ATOMIC); else uncmem = user_mem; @@ -268,7 +268,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, * This is a partial IO. We need to read the full page * before to write the changes. */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); if (!uncmem) { pr_info("Error allocating temp memory!\n"); ret = -ENOMEM; -- 1.7.9.5 ^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 0:38 [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write Minchan Kim @ 2013-01-28 7:16 ` Pekka Enberg 2013-01-28 11:24 ` Jerome Marchand 2013-01-28 23:21 ` Minchan Kim 2013-01-30 4:20 ` Greg Kroah-Hartman 1 sibling, 2 replies; 11+ messages in thread From: Pekka Enberg @ 2013-01-28 7:16 UTC (permalink / raw) To: Minchan Kim Cc: Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable, Jerome Marchand On Mon, Jan 28, 2013 at 2:38 AM, Minchan Kim <minchan@kernel.org> wrote: > Now zram allocates new page with GFP_KERNEL in zram I/O path > if IO is partial. Unfortunately, It may cuase deadlock with s/cuase/cause/g > reclaim path so this patch solves the problem. It'd be nice to know about the problem in more detail. I'm also curious on why you decided on GFP_ATOMIC for the read path and GFP_NOIO in the write path. > > Cc: stable@vger.kernel.org > Cc: Jerome Marchand <jmarchan@redhat.com> > Acked-by: Nitin Gupta <ngupta@vflare.org> > Signed-off-by: Minchan Kim <minchan@kernel.org> > --- > drivers/staging/zram/zram_drv.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c > index 61fb8f1..b285b3a 100644 > --- a/drivers/staging/zram/zram_drv.c > +++ b/drivers/staging/zram/zram_drv.c > @@ -220,7 +220,7 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, > user_mem = kmap_atomic(page); > if (is_partial_io(bvec)) > /* Use a temporary buffer to decompress the page */ > - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); > + uncmem = kmalloc(PAGE_SIZE, GFP_ATOMIC); > else > uncmem = user_mem; > > @@ -268,7 +268,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, > * This is a partial IO. We need to read the full page > * before to write the changes. > */ > - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); > + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); > if (!uncmem) { > pr_info("Error allocating temp memory!\n"); > ret = -ENOMEM; > -- > 1.7.9.5 > > -- > 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> ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 7:16 ` Pekka Enberg @ 2013-01-28 11:24 ` Jerome Marchand 2013-01-28 13:26 ` Pekka Enberg 2013-01-28 23:21 ` Minchan Kim 1 sibling, 1 reply; 11+ messages in thread From: Jerome Marchand @ 2013-01-28 11:24 UTC (permalink / raw) To: Pekka Enberg Cc: Minchan Kim, Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable On 01/28/2013 08:16 AM, Pekka Enberg wrote: > On Mon, Jan 28, 2013 at 2:38 AM, Minchan Kim <minchan@kernel.org> wrote: >> Now zram allocates new page with GFP_KERNEL in zram I/O path >> if IO is partial. Unfortunately, It may cuase deadlock with > > s/cuase/cause/g > >> reclaim path so this patch solves the problem. > > It'd be nice to know about the problem in more detail. I'm also > curious on why you decided on GFP_ATOMIC for the read path and > GFP_NOIO in the write path. This is because we're holding a kmap_atomic page in the read path. Jerome > >> >> Cc: stable@vger.kernel.org >> Cc: Jerome Marchand <jmarchan@redhat.com> >> Acked-by: Nitin Gupta <ngupta@vflare.org> >> Signed-off-by: Minchan Kim <minchan@kernel.org> >> --- >> drivers/staging/zram/zram_drv.c | 4 ++-- >> 1 file changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c >> index 61fb8f1..b285b3a 100644 >> --- a/drivers/staging/zram/zram_drv.c >> +++ b/drivers/staging/zram/zram_drv.c >> @@ -220,7 +220,7 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, >> user_mem = kmap_atomic(page); >> if (is_partial_io(bvec)) >> /* Use a temporary buffer to decompress the page */ >> - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); >> + uncmem = kmalloc(PAGE_SIZE, GFP_ATOMIC); >> else >> uncmem = user_mem; >> >> @@ -268,7 +268,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, >> * This is a partial IO. We need to read the full page >> * before to write the changes. >> */ >> - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); >> + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); >> if (!uncmem) { >> pr_info("Error allocating temp memory!\n"); >> ret = -ENOMEM; >> -- >> 1.7.9.5 >> >> -- >> 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> ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 11:24 ` Jerome Marchand @ 2013-01-28 13:26 ` Pekka Enberg 2013-01-28 13:47 ` Jerome Marchand 0 siblings, 1 reply; 11+ messages in thread From: Pekka Enberg @ 2013-01-28 13:26 UTC (permalink / raw) To: Jerome Marchand Cc: Minchan Kim, Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable On Mon, Jan 28, 2013 at 1:24 PM, Jerome Marchand <jmarchan@redhat.com> wrote: > On 01/28/2013 08:16 AM, Pekka Enberg wrote: >> On Mon, Jan 28, 2013 at 2:38 AM, Minchan Kim <minchan@kernel.org> wrote: >>> Now zram allocates new page with GFP_KERNEL in zram I/O path >>> if IO is partial. Unfortunately, It may cuase deadlock with >> >> s/cuase/cause/g >> >>> reclaim path so this patch solves the problem. >> >> It'd be nice to know about the problem in more detail. I'm also >> curious on why you decided on GFP_ATOMIC for the read path and >> GFP_NOIO in the write path. > > This is because we're holding a kmap_atomic page in the read path. Okay, so that's about partial *reads* and not even mentioned in the changelog, no? AFAICT, you could rearrange the code in zram_bvec_read() as follows: if (is_partial_io(bvec)) /* Use a temporary buffer to decompress the page */ uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); else { uncmem = user_mem = kmap_atomic(page); } and avoid the GFP_ATOMIC allocation. ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 13:26 ` Pekka Enberg @ 2013-01-28 13:47 ` Jerome Marchand 0 siblings, 0 replies; 11+ messages in thread From: Jerome Marchand @ 2013-01-28 13:47 UTC (permalink / raw) To: Pekka Enberg Cc: Minchan Kim, Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable On 01/28/2013 02:26 PM, Pekka Enberg wrote: > On Mon, Jan 28, 2013 at 1:24 PM, Jerome Marchand <jmarchan@redhat.com> wrote: >> On 01/28/2013 08:16 AM, Pekka Enberg wrote: >>> On Mon, Jan 28, 2013 at 2:38 AM, Minchan Kim <minchan@kernel.org> wrote: >>>> Now zram allocates new page with GFP_KERNEL in zram I/O path >>>> if IO is partial. Unfortunately, It may cuase deadlock with >>> >>> s/cuase/cause/g >>> >>>> reclaim path so this patch solves the problem. >>> >>> It'd be nice to know about the problem in more detail. I'm also >>> curious on why you decided on GFP_ATOMIC for the read path and >>> GFP_NOIO in the write path. >> >> This is because we're holding a kmap_atomic page in the read path. > > Okay, so that's about partial *reads* and not even mentioned in the > changelog, no? > > AFAICT, you could rearrange the code in zram_bvec_read() as follows: > > if (is_partial_io(bvec)) > /* Use a temporary buffer to decompress the page */ > uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); > else { > uncmem = user_mem = kmap_atomic(page); > } > > and avoid the GFP_ATOMIC allocation. > user_mem still has to be mapped in case of partial I/O too. But the temporary buffer allocation could happen before. The allocation still would need to be GFP_NOIO to avoid possible deadlocks. Anyhow, the commit message could definitely be more explicit. Regards, Jerome ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 7:16 ` Pekka Enberg 2013-01-28 11:24 ` Jerome Marchand @ 2013-01-28 23:21 ` Minchan Kim 2013-01-29 7:11 ` Pekka Enberg 1 sibling, 1 reply; 11+ messages in thread From: Minchan Kim @ 2013-01-28 23:21 UTC (permalink / raw) To: Pekka Enberg Cc: Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable, Jerome Marchand On Mon, Jan 28, 2013 at 09:16:35AM +0200, Pekka Enberg wrote: > On Mon, Jan 28, 2013 at 2:38 AM, Minchan Kim <minchan@kernel.org> wrote: > > Now zram allocates new page with GFP_KERNEL in zram I/O path > > if IO is partial. Unfortunately, It may cuase deadlock with > > s/cuase/cause/g Thanks! > > > reclaim path so this patch solves the problem. > > It'd be nice to know about the problem in more detail. I'm also > curious on why you decided on GFP_ATOMIC for the read path and > GFP_NOIO in the write path. In read path, we called kmap_atomic. How about this? ------------------------- >8 ------------------------------- >From 9f8756ae0b0f2819f93cb94dcd38da372843aa12 Mon Sep 17 00:00:00 2001 From: Minchan Kim <minchan@kernel.org> Date: Mon, 21 Jan 2013 13:58:52 +0900 Subject: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial read/write Now zram allocates new page with GFP_KERNEL in zram I/O path if IO is partial. Unfortunately, It may cause deadlock with reclaim path like below. write_page from fs fs_lock allocation(GFP_KERNEL) reclaim pageout write_page from fs fs_lock <-- deadlock This patch fixes it by using GFP_ATOMIC and GFP_NOIO. In read path, we called kmap_atomic so that we need GFP_ATOMIC while we need GFP_NOIO in write path. Cc: stable@vger.kernel.org Cc: Jerome Marchand <jmarchan@redhat.com> Acked-by: Nitin Gupta <ngupta@vflare.org> Signed-off-by: Minchan Kim <minchan@kernel.org> --- We could use GFP_IO instead of GFP_ATOMIC in zram_bvec_read with some modification related to buffer allocation in case of partial IO. But it needs more churn and prevent merge this patch into stable if we should send this to stable so I'd like to keep it as simple as possbile. GFP_IO usage could be separate patch after we merge it. Thanks. drivers/staging/zram/zram_drv.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c index 61fb8f1..b285b3a 100644 --- a/drivers/staging/zram/zram_drv.c +++ b/drivers/staging/zram/zram_drv.c @@ -220,7 +220,7 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, user_mem = kmap_atomic(page); if (is_partial_io(bvec)) /* Use a temporary buffer to decompress the page */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); + uncmem = kmalloc(PAGE_SIZE, GFP_ATOMIC); else uncmem = user_mem; @@ -268,7 +268,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, * This is a partial IO. We need to read the full page * before to write the changes. */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); if (!uncmem) { pr_info("Error allocating temp memory!\n"); ret = -ENOMEM; -- 1.7.9.5 -- Kind regards, Minchan Kim ^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 23:21 ` Minchan Kim @ 2013-01-29 7:11 ` Pekka Enberg 2013-01-30 1:32 ` Minchan Kim 0 siblings, 1 reply; 11+ messages in thread From: Pekka Enberg @ 2013-01-29 7:11 UTC (permalink / raw) To: Minchan Kim Cc: Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable, Jerome Marchand On Tue, Jan 29, 2013 at 1:21 AM, Minchan Kim <minchan@kernel.org> wrote: > How about this? > ------------------------- >8 ------------------------------- > > From 9f8756ae0b0f2819f93cb94dcd38da372843aa12 Mon Sep 17 00:00:00 2001 > From: Minchan Kim <minchan@kernel.org> > Date: Mon, 21 Jan 2013 13:58:52 +0900 > Subject: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial read/write > > Now zram allocates new page with GFP_KERNEL in zram I/O path > if IO is partial. Unfortunately, It may cause deadlock with > reclaim path like below. > > write_page from fs > fs_lock > allocation(GFP_KERNEL) > reclaim > pageout > write_page from fs > fs_lock <-- deadlock > > This patch fixes it by using GFP_ATOMIC and GFP_NOIO. > In read path, we called kmap_atomic so that we need GFP_ATOMIC > while we need GFP_NOIO in write path. The patch description makes sense now. Thanks! On Tue, Jan 29, 2013 at 1:21 AM, Minchan Kim <minchan@kernel.org> wrote: > We could use GFP_IO instead of GFP_ATOMIC in zram_bvec_read with > some modification related to buffer allocation in case of partial IO. > But it needs more churn and prevent merge this patch into stable > if we should send this to stable so I'd like to keep it as simple > as possbile. GFP_IO usage could be separate patch after we merge it. I don't see why something like below couldn't be merged for stable. Going for GFP_ATOMIC might seem like the simplest thing to go for but usually bites you in the end. Pekka ------------------------- >8 ------------------------------- >From 936a12b423c58542628d6fd683e859f752eb3d41 Mon Sep 17 00:00:00 2001 From: Minchan Kim <minchan@kernel.org> Date: Mon, 21 Jan 2013 13:58:52 +0900 Subject: [PATCH] zram: Fix deadlock bug in partial read/write Now zram allocates new page with GFP_KERNEL in zram I/O path if IO is partial. Unfortunately, It may cause deadlock with reclaim path like below. write_page from fs fs_lock allocation(GFP_KERNEL) reclaim pageout write_page from fs fs_lock <-- deadlock This patch fixes it by using GFP_NOIO. In read path, we reorganize code flow so that kmap_atomic is called after the GFP_NOIO allocation. Cc: stable@vger.kernel.org Cc: Jerome Marchand <jmarchan@redhat.com> Acked-by: Nitin Gupta <ngupta@vflare.org> Signed-off-by: Minchan Kim <minchan@kernel.org> [ penberg@kernel.org: don't use GFP_ATOMIC ] Signed-off-by: Pekka Enberg <penberg@kernel.org> --- drivers/staging/zram/zram_drv.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c index f2a73bd..071e058 100644 --- a/drivers/staging/zram/zram_drv.c +++ b/drivers/staging/zram/zram_drv.c @@ -228,11 +228,12 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, return 0; } - user_mem = kmap_atomic(page); if (is_partial_io(bvec)) /* Use a temporary buffer to decompress the page */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); - else + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); + + user_mem = kmap_atomic(page); + if (!is_partial_io(bvec)) uncmem = user_mem; if (!uncmem) { @@ -279,7 +280,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, * This is a partial IO. We need to read the full page * before to write the changes. */ - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); if (!uncmem) { pr_info("Error allocating temp memory!\n"); ret = -ENOMEM; -- 1.7.11.7 ^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-29 7:11 ` Pekka Enberg @ 2013-01-30 1:32 ` Minchan Kim 0 siblings, 0 replies; 11+ messages in thread From: Minchan Kim @ 2013-01-30 1:32 UTC (permalink / raw) To: Pekka Enberg Cc: Greg Kroah-Hartman, linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, stable, Jerome Marchand On Tue, Jan 29, 2013 at 09:11:08AM +0200, Pekka Enberg wrote: > On Tue, Jan 29, 2013 at 1:21 AM, Minchan Kim <minchan@kernel.org> wrote: > > How about this? > > ------------------------- >8 ------------------------------- > > > > From 9f8756ae0b0f2819f93cb94dcd38da372843aa12 Mon Sep 17 00:00:00 2001 > > From: Minchan Kim <minchan@kernel.org> > > Date: Mon, 21 Jan 2013 13:58:52 +0900 > > Subject: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial read/write > > > > Now zram allocates new page with GFP_KERNEL in zram I/O path > > if IO is partial. Unfortunately, It may cause deadlock with > > reclaim path like below. > > > > write_page from fs > > fs_lock > > allocation(GFP_KERNEL) > > reclaim > > pageout > > write_page from fs > > fs_lock <-- deadlock > > > > This patch fixes it by using GFP_ATOMIC and GFP_NOIO. > > In read path, we called kmap_atomic so that we need GFP_ATOMIC > > while we need GFP_NOIO in write path. > > The patch description makes sense now. Thanks! > > On Tue, Jan 29, 2013 at 1:21 AM, Minchan Kim <minchan@kernel.org> wrote: > > We could use GFP_IO instead of GFP_ATOMIC in zram_bvec_read with > > some modification related to buffer allocation in case of partial IO. > > But it needs more churn and prevent merge this patch into stable > > if we should send this to stable so I'd like to keep it as simple > > as possbile. GFP_IO usage could be separate patch after we merge it. > > I don't see why something like below couldn't be merged for stable. > Going for GFP_ATOMIC might seem like the simplest thing to go for but > usually bites you in the end. Looks good to me. I will resend it. Thanks, Pekka. > > Pekka > > ------------------------- >8 ------------------------------- > > >From 936a12b423c58542628d6fd683e859f752eb3d41 Mon Sep 17 00:00:00 2001 > From: Minchan Kim <minchan@kernel.org> > Date: Mon, 21 Jan 2013 13:58:52 +0900 > Subject: [PATCH] zram: Fix deadlock bug in partial read/write > > Now zram allocates new page with GFP_KERNEL in zram I/O path > if IO is partial. Unfortunately, It may cause deadlock with > reclaim path like below. > > write_page from fs > fs_lock > allocation(GFP_KERNEL) > reclaim > pageout > write_page from fs > fs_lock <-- deadlock > > This patch fixes it by using GFP_NOIO. In read path, we > reorganize code flow so that kmap_atomic is called after the > GFP_NOIO allocation. > > Cc: stable@vger.kernel.org > Cc: Jerome Marchand <jmarchan@redhat.com> > Acked-by: Nitin Gupta <ngupta@vflare.org> > Signed-off-by: Minchan Kim <minchan@kernel.org> > [ penberg@kernel.org: don't use GFP_ATOMIC ] > Signed-off-by: Pekka Enberg <penberg@kernel.org> > --- > drivers/staging/zram/zram_drv.c | 9 +++++---- > 1 file changed, 5 insertions(+), 4 deletions(-) > > diff --git a/drivers/staging/zram/zram_drv.c b/drivers/staging/zram/zram_drv.c > index f2a73bd..071e058 100644 > --- a/drivers/staging/zram/zram_drv.c > +++ b/drivers/staging/zram/zram_drv.c > @@ -228,11 +228,12 @@ static int zram_bvec_read(struct zram *zram, struct bio_vec *bvec, > return 0; > } > > - user_mem = kmap_atomic(page); > if (is_partial_io(bvec)) > /* Use a temporary buffer to decompress the page */ > - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); > - else > + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); > + > + user_mem = kmap_atomic(page); > + if (!is_partial_io(bvec)) > uncmem = user_mem; > > if (!uncmem) { > @@ -279,7 +280,7 @@ static int zram_bvec_write(struct zram *zram, struct bio_vec *bvec, u32 index, > * This is a partial IO. We need to read the full page > * before to write the changes. > */ > - uncmem = kmalloc(PAGE_SIZE, GFP_KERNEL); > + uncmem = kmalloc(PAGE_SIZE, GFP_NOIO); > if (!uncmem) { > pr_info("Error allocating temp memory!\n"); > ret = -ENOMEM; > -- > 1.7.11.7 > > -- > 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> -- Kind regards, Minchan Kim ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-28 0:38 [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write Minchan Kim 2013-01-28 7:16 ` Pekka Enberg @ 2013-01-30 4:20 ` Greg Kroah-Hartman 2013-01-30 8:21 ` Minchan Kim 1 sibling, 1 reply; 11+ messages in thread From: Greg Kroah-Hartman @ 2013-01-30 4:20 UTC (permalink / raw) To: Minchan Kim Cc: linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, Pekka Enberg, stable, Jerome Marchand On Mon, Jan 28, 2013 at 09:38:23AM +0900, Minchan Kim wrote: > Now zram allocates new page with GFP_KERNEL in zram I/O path > if IO is partial. Unfortunately, It may cuase deadlock with > reclaim path so this patch solves the problem. > > Cc: stable@vger.kernel.org > Cc: Jerome Marchand <jmarchan@redhat.com> > Acked-by: Nitin Gupta <ngupta@vflare.org> > Signed-off-by: Minchan Kim <minchan@kernel.org> > --- > drivers/staging/zram/zram_drv.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) Due to the discussion on this series, I don't know what patch to apply, so care to do a v6 of this with the patches that everyone has finally agreed on? I'm dropping these from my to-apply queue now. thanks, greg k-h ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-30 4:20 ` Greg Kroah-Hartman @ 2013-01-30 8:21 ` Minchan Kim 2013-01-31 5:41 ` Minchan Kim 0 siblings, 1 reply; 11+ messages in thread From: Minchan Kim @ 2013-01-30 8:21 UTC (permalink / raw) To: Greg Kroah-Hartman Cc: linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, Pekka Enberg, stable, Jerome Marchand Hi Greg, On Tue, Jan 29, 2013 at 11:20:06PM -0500, Greg Kroah-Hartman wrote: > On Mon, Jan 28, 2013 at 09:38:23AM +0900, Minchan Kim wrote: > > Now zram allocates new page with GFP_KERNEL in zram I/O path > > if IO is partial. Unfortunately, It may cuase deadlock with > > reclaim path so this patch solves the problem. > > > > Cc: stable@vger.kernel.org > > Cc: Jerome Marchand <jmarchan@redhat.com> > > Acked-by: Nitin Gupta <ngupta@vflare.org> > > Signed-off-by: Minchan Kim <minchan@kernel.org> > > --- > > drivers/staging/zram/zram_drv.c | 4 ++-- > > 1 file changed, 2 insertions(+), 2 deletions(-) > > Due to the discussion on this series, I don't know what patch to apply, > so care to do a v6 of this with the patches that everyone has finally > agreed on? I already sent v6. https://lkml.org/lkml/2013/1/29/680 Thanks. -- Kind regards, Minchan Kim ^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write 2013-01-30 8:21 ` Minchan Kim @ 2013-01-31 5:41 ` Minchan Kim 0 siblings, 0 replies; 11+ messages in thread From: Minchan Kim @ 2013-01-31 5:41 UTC (permalink / raw) To: Greg Kroah-Hartman Cc: linux-mm, linux-kernel, Dan Magenheimer, Nitin Gupta, Konrad Rzeszutek Wilk, Seth Jennings, Pekka Enberg, stable, Jerome Marchand On Wed, Jan 30, 2013 at 05:21:12PM +0900, Minchan Kim wrote: > Hi Greg, > > On Tue, Jan 29, 2013 at 11:20:06PM -0500, Greg Kroah-Hartman wrote: > > On Mon, Jan 28, 2013 at 09:38:23AM +0900, Minchan Kim wrote: > > > Now zram allocates new page with GFP_KERNEL in zram I/O path > > > if IO is partial. Unfortunately, It may cuase deadlock with > > > reclaim path so this patch solves the problem. > > > > > > Cc: stable@vger.kernel.org > > > Cc: Jerome Marchand <jmarchan@redhat.com> > > > Acked-by: Nitin Gupta <ngupta@vflare.org> > > > Signed-off-by: Minchan Kim <minchan@kernel.org> > > > --- > > > drivers/staging/zram/zram_drv.c | 4 ++-- > > > 1 file changed, 2 insertions(+), 2 deletions(-) > > > > Due to the discussion on this series, I don't know what patch to apply, > > so care to do a v6 of this with the patches that everyone has finally > > agreed on? > > I already sent v6. > https://lkml.org/lkml/2013/1/29/680 Greg, If you have a trouble to merge it, let me know it. Will resend it when linux-next comes in. Thanks. -- Kind regards, Minchan Kim ^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2013-01-31 5:41 UTC | newest] Thread overview: 11+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2013-01-28 0:38 [RESEND PATCH v5 1/4] zram: Fix deadlock bug in partial write Minchan Kim 2013-01-28 7:16 ` Pekka Enberg 2013-01-28 11:24 ` Jerome Marchand 2013-01-28 13:26 ` Pekka Enberg 2013-01-28 13:47 ` Jerome Marchand 2013-01-28 23:21 ` Minchan Kim 2013-01-29 7:11 ` Pekka Enberg 2013-01-30 1:32 ` Minchan Kim 2013-01-30 4:20 ` Greg Kroah-Hartman 2013-01-30 8:21 ` Minchan Kim 2013-01-31 5:41 ` Minchan Kim
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox