Minchan Kim
7e5a5104c6
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
Acked-by: Jerome Marchand <jmarchand@redhat.com>
Acked-by: Nitin Gupta <ngupta@vflare.org>
[ penberg@kernel.org: don't use GFP_ATOMIC ]
Signed-off-by: Pekka Enberg <penberg@kernel.org>
Signed-off-by: Minchan Kim <minchan@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2013-02-03 17:52:49 -08:00
..
2013-01-22 13:37:21 +01:00
2013-01-03 15:57:02 -08:00
2013-01-14 13:29:15 -05:00
2013-01-03 15:57:04 -08:00
2013-01-03 15:57:16 -08:00
2013-01-24 19:04:16 +08:00
2013-01-08 07:31:49 -08:00
2013-01-20 16:44:28 -08:00
2012-12-12 18:07:07 -08:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:15 -08:00
2013-01-23 20:30:52 -08:00
2013-01-03 15:57:15 -08:00
2013-01-03 15:57:16 -08:00
2013-01-22 22:33:46 +01:00
2013-01-15 14:18:04 +01:00
2013-01-03 15:57:02 -08:00
2013-01-22 13:28:40 +01:00
2013-01-24 10:17:49 -08:00
2013-01-09 08:43:56 -08:00
2012-12-13 12:00:02 -08:00
2013-01-03 15:57:16 -08:00
2013-01-17 12:27:08 +01:00
2013-01-21 13:45:23 +10:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:16 -08:00
2013-01-17 11:58:00 -08:00
2013-01-09 21:47:22 -08:00
2013-01-22 16:43:34 +01:00
2013-01-03 15:57:03 -08:00
2013-01-18 13:43:43 +01:00
2013-02-02 16:03:32 +01:00
2013-01-03 15:57:15 -08:00
2013-01-04 10:30:11 -08:00
2013-01-03 15:57:14 -08:00
2012-12-11 14:08:47 -08:00
2012-12-14 14:42:53 -08:00
2013-01-03 15:57:02 -08:00
2013-01-02 17:58:41 -08:00
2012-12-18 15:19:06 +10:30
2013-01-03 15:57:14 -08:00
2012-12-21 17:08:06 -08:00
2013-01-24 12:42:50 -08:00
2013-01-03 15:57:14 -08:00
2013-01-03 15:57:14 -08:00
2013-01-24 12:19:23 +00:00
2013-01-22 17:22:47 -08:00
2013-01-23 20:30:52 -08:00
2013-01-03 15:57:03 -08:00
2013-01-12 15:33:01 -08:00
2013-01-03 15:57:16 -08:00
2012-12-19 10:58:53 +00:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:03 -08:00
2013-01-22 16:36:23 -08:00
2012-12-12 11:45:16 -08:00
2013-01-08 18:53:56 -08:00
2013-01-25 21:25:02 -08:00
2013-01-03 13:10:53 +01:00
2013-01-08 18:53:56 -08:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:16 -08:00
2012-12-12 18:07:07 -08:00
2012-12-19 08:19:07 -08:00
2012-12-11 13:13:55 -08:00
2013-01-15 09:38:59 +09:00
2013-01-03 15:57:16 -08:00
2013-01-03 15:57:16 -08:00
2013-01-26 10:07:52 +00:00
2013-01-16 15:57:54 +01:00
2013-01-03 15:57:03 -08:00
2013-01-03 15:57:01 -08:00
2013-01-11 20:57:58 +09:00
2013-01-03 15:57:16 -08:00
2012-12-19 15:11:41 +00:00
2013-01-08 07:31:49 -08:00
2013-02-03 17:52:49 -08:00
2013-01-10 21:00:37 -08:00
2013-01-03 15:57:02 -08:00
2013-01-17 14:02:55 -08:00
2012-12-12 12:05:15 -08:00
2013-01-23 11:27:08 -08:00
2013-01-15 10:45:26 -07:00
2012-12-15 14:25:10 -08:00
2013-01-23 20:35:02 -08:00
2012-12-18 09:58:09 -08:00
2013-01-03 15:57:01 -08:00
2013-01-03 15:57:01 -08:00
2013-01-03 15:57:01 -08:00
2013-01-02 12:07:05 +01:00
2013-01-18 12:02:52 -08:00
2013-01-03 15:57:01 -08:00