lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20121030121146.GC5052@swordfish.minsk.epam.com>
Date:	Tue, 30 Oct 2012 15:11:46 +0300
From:	Sergey Senozhatsky <sergey.senozhatsky@...il.com>
To:	Nitin Gupta <ngupta@...are.org>
Cc:	Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
	linux-kernel@...r.kernel.org,
	Sergey Senozhatsky <sergey.senozhatsky@...il.com>
Subject: Re: [PATCH 1/2] zram: forbid IO operations from within
 zram_init_device()


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@...il.com>
> 
> ---
> 
>  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@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ