zram: fix race between reset and flushing pending work
authorMinchan Kim <[email protected]>
Thu, 30 Jan 2014 23:45:58 +0000 (15:45 -0800)
committerLinus Torvalds <[email protected]>
Fri, 31 Jan 2014 00:56:55 +0000 (16:56 -0800)
commitda4a04126baa3be03bc566d4a2ee0944c5e783d0
treefec417b4bf836105091c4f32c481442c50cabefb
parenteae70d06846199afc97524ed986b910836c0abe5
zram: fix race between reset and flushing pending work

Dan and Sergey reported that there is a racy between reset and flushing
of pending work so that it could make oops by freeing zram->meta in
reset while zram_slot_free can access zram->meta if new request is
adding during the race window.

This patch moves flush after taking init_lock so it prevents new request
so that it closes the race.

Signed-off-by: Minchan Kim <[email protected]>
Reported-by: Dan Carpenter <[email protected]>
Cc: Nitin Gupta <[email protected]>
Cc: Jerome Marchand <[email protected]>
Tested-by: Sergey Senozhatsky <[email protected]>
Cc: <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
drivers/block/zram/zram_drv.c