Re: [PATCH 1/2] zram: forbid IO operations from withinzram_init_device()

From: Sergey Senozhatsky
Date: Tue Oct 30 2012 - 08:14:03 EST



please ignore this patch. on a second thought -- I'm sure it will not fix anything.
will rework and resend.


-ss

On (10/30/12 12:01), Sergey Senozhatsky wrote:
> zram: forbid IO operations from within zram_init_device()
>
> Allocation operations in zram_make_request() -> zram_init_device() should not
> raise IO and nested zram_make_request() -> zram_init_device() from IRQ context,
> thus we must use GFP_NOIO flag.
>
> =================================
> [ INFO: inconsistent lock state ]
> 3.7.0-rc2-dbg-01597-ge5cf11d-dirty #1397 Tainted: G C O
> ---------------------------------
> inconsistent {RECLAIM_FS-ON-W} -> {IN-RECLAIM_FS-R} usage.
> kswapd0/453 [HC0[0]:SC0[0]:HE1:SE1] takes:
> (&zram->init_lock){+++++-}, at: [<ffffffffa0145ca8>] zram_make_request+0x48/0x270 [zram]
> {RECLAIM_FS-ON-W} state was registered at:
> [<ffffffff810ac82c>] mark_held_locks+0x8c/0x110
> [<ffffffff810acf69>] lockdep_trace_alloc+0x79/0xd0
> [<ffffffff8111de6a>] __alloc_pages_nodemask+0x8a/0x920
> [<ffffffff8111e717>] __get_free_pages+0x17/0x50
> [<ffffffff8115b1a9>] kmalloc_order_trace+0x39/0x180
> [<ffffffffa0145abd>] zram_init_device+0x7d/0x220 [zram]
> [<ffffffffa0145ebe>] zram_make_request+0x25e/0x270 [zram]
> [<ffffffff812ebc92>] generic_make_request+0xc2/0x110
> [<ffffffff812ebd4a>] submit_bio+0x6a/0x140
> [<ffffffff8119f27b>] submit_bh+0xfb/0x130
> [<ffffffff811a2d85>] block_read_full_page+0x2a5/0x3a0
> [<ffffffff811a6bf8>] blkdev_readpage+0x18/0x20
> [<ffffffff8112163a>] __do_page_cache_readahead+0x39a/0x3a0
> [<ffffffff81121951>] ra_submit+0x21/0x30
> [<ffffffff81121b2e>] ondemand_readahead+0x1ce/0x470
> [<ffffffff81121eb1>] page_cache_sync_readahead+0x31/0x50
> [<ffffffff811175d8>] generic_file_aio_read+0x518/0x780
> [<ffffffff811a6740>] blkdev_aio_read+0xe0/0x210
> [<ffffffff81169237>] do_sync_read+0xa7/0xe0
> [<ffffffff811699a5>] vfs_read+0xa5/0x180
> [<ffffffff81169ad2>] sys_read+0x52/0xa0
> [<ffffffff815dc9c6>] tracesys+0xd4/0xd9
> irq event stamp: 28815031
> hardirqs last enabled at (28815031): [<ffffffff81300470>] throtl_update_dispatch_stats+0xa0/0x110
> hardirqs last disabled at (28815030): [<ffffffff8130042b>] throtl_update_dispatch_stats+0x5b/0x110
> softirqs last enabled at (28813582): [<ffffffff8104b437>] __do_softirq+0x147/0x3b0
> softirqs last disabled at (28813565): [<ffffffff815ddbbc>] call_softirq+0x1c/0x30
> CPU0
> ----
> lock(&zram->init_lock);
> <Interrupt>
> lock(&zram->init_lock);
> no locks held by kswapd0/453.
> Pid: 453, comm: kswapd0 Tainted: G C O 3.7.0-rc2-dbg-01597-ge5cf11d-dirty #1397
> Call Trace:
> [<ffffffff815c7aff>] print_usage_bug+0x2a3/0x2b4
> [<ffffffff81010aff>] ? save_stack_trace+0x2f/0x50
> [<ffffffff810a8b90>] ? print_irq_inversion_bug+0x220/0x220
> [<ffffffff810aa8f0>] mark_lock+0x270/0x620
> [<ffffffff810ab15b>] __lock_acquire+0x4bb/0xb70
> [<ffffffff810abe61>] lock_acquire+0xa1/0x1e0
> [<ffffffffa0145ca8>] ? zram_make_request+0x48/0x270 [zram]
> [<ffffffff815d05bc>] down_read+0x4c/0x61
> [<ffffffffa0145ca8>] ? zram_make_request+0x48/0x270 [zram]
> [<ffffffffa0145ca8>] zram_make_request+0x48/0x270 [zram]
> [<ffffffff812ebc92>] generic_make_request+0xc2/0x110
> [<ffffffff812ebd4a>] submit_bio+0x6a/0x140
> [<ffffffff8119f27b>] submit_bh+0xfb/0x130
> [<ffffffff811f430d>] reiserfs_write_full_page+0x2cd/0x5b0
> [<ffffffff8111f555>] ? clear_page_dirty_for_io+0x105/0x130
> [<ffffffff811f4626>] reiserfs_writepage+0x36/0x40
> [<ffffffff8112884b>] shrink_page_list+0x74b/0xa20
> [<ffffffff811290c8>] shrink_inactive_list+0x1e8/0x4b0
> [<ffffffff81129759>] shrink_lruvec+0x3c9/0x530
> [<ffffffff8112a760>] kswapd+0x690/0xd70
> [<ffffffff8112a0d0>] ? try_to_free_pages+0x330/0x330
> [<ffffffff8106b90b>] kthread+0xdb/0xe0
> [<ffffffff815d3170>] ? _raw_spin_unlock_irq+0x30/0x50
> [<ffffffff8106b830>] ? __init_kthread_worker+0x70/0x70
> [<ffffffff815dc76c>] ret_from_fork+0x7c/0xb0
> [<ffffffff8106b830>] ? __init_kthread_worker+0x70/0x70
>
>
> Signed-off-by: Sergey Senozhatsky <sergey.senozhatsky@xxxxxxxxx>
>
> ---
>
> 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 fb4a7c9..d2e0a85 100644
> --- a/drivers/staging/zram/zram_drv.c
> +++ b/drivers/staging/zram/zram_drv.c
> @@ -548,7 +548,7 @@ int zram_init_device(struct zram *zram)
>
> zram_set_disksize(zram, totalram_pages << PAGE_SHIFT);
>
> - zram->compress_workmem = kzalloc(LZO1X_MEM_COMPRESS, GFP_KERNEL);
> + zram->compress_workmem = kzalloc(LZO1X_MEM_COMPRESS, GFP_NOIO);
> if (!zram->compress_workmem) {
> pr_err("Error allocating compressor working memory!\n");
> ret = -ENOMEM;
> @@ -556,7 +556,7 @@ int zram_init_device(struct zram *zram)
> }
>
> zram->compress_buffer =
> - (void *)__get_free_pages(GFP_KERNEL | __GFP_ZERO, 1);
> + (void *)__get_free_pages(GFP_NOIO | __GFP_ZERO, 1);
> if (!zram->compress_buffer) {
> pr_err("Error allocating compressor buffer space\n");
> ret = -ENOMEM;
>
>
--
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/