diff options
author | Shaohua Li <shli@kernel.org> | 2012-03-21 19:34:17 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-21 20:55:00 -0400 |
commit | 052b1987faca3606109d88d96bce124851f7c4c2 (patch) | |
tree | 879df883edb01ea6e0da880e391b06bb69058129 /mm/swapfile.c | |
parent | 1480de0340a8d5f094b74d7c4b902456c9a06903 (diff) |
swap: don't do discard if no discard option added
When swapon() was not passed the SWAP_FLAG_DISCARD option, sys_swapon()
will still perform a discard operation. This can cause problems if
discard is slow or buggy.
Reverse the order of the check so that a discard operation is performed
only if the sys_swapon() caller is attempting to enable discard.
Signed-off-by: Shaohua Li <shli@fusionio.com>
Reported-by: Holger Kiehl <Holger.Kiehl@dwd.de>
Tested-by: Holger Kiehl <Holger.Kiehl@dwd.de>
Cc: Hugh Dickins <hughd@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/swapfile.c')
-rw-r--r-- | mm/swapfile.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/swapfile.c b/mm/swapfile.c index b82c028cfcc6..21b56945c5d2 100644 --- a/mm/swapfile.c +++ b/mm/swapfile.c | |||
@@ -2103,7 +2103,7 @@ SYSCALL_DEFINE2(swapon, const char __user *, specialfile, int, swap_flags) | |||
2103 | p->flags |= SWP_SOLIDSTATE; | 2103 | p->flags |= SWP_SOLIDSTATE; |
2104 | p->cluster_next = 1 + (random32() % p->highest_bit); | 2104 | p->cluster_next = 1 + (random32() % p->highest_bit); |
2105 | } | 2105 | } |
2106 | if (discard_swap(p) == 0 && (swap_flags & SWAP_FLAG_DISCARD)) | 2106 | if ((swap_flags & SWAP_FLAG_DISCARD) && discard_swap(p) == 0) |
2107 | p->flags |= SWP_DISCARDABLE; | 2107 | p->flags |= SWP_DISCARDABLE; |
2108 | } | 2108 | } |
2109 | 2109 | ||