aboutsummaryrefslogtreecommitdiffstats
path: root/mm/swapfile.c
diff options
context:
space:
mode:
authorCesar Eduardo Barros <cesarb@cesarb.net>2011-03-22 19:33:24 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2011-03-22 20:44:07 -0400
commit9b01c350af4fb00fe2ab66ff9bf16058c50b69bd (patch)
tree246a4e93384acaca2ae91826448bfed5da08cb07 /mm/swapfile.c
parentf2090d2df51d7cdb2f952dcfdcd8baaac0aec444 (diff)
sys_swapon: do only cleanup in the cleanup blocks
The only way error is 0 in the cleanup blocks is when the function is returning successfully. In this case, the cleanup blocks were setting S_SWAPFILE in the S_ISREG case. But this is not a cleanup. Move the setting of S_SWAPFILE to just before the "goto out;" to make this more clear. At this point, we do not need to test for inode because it will never be NULL. Signed-off-by: Cesar Eduardo Barros <cesarb@cesarb.net> Tested-by: Eric B Munson <emunson@mgebm.net> Acked-by: Eric B Munson <emunson@mgebm.net> Reviewed-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> 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.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/mm/swapfile.c b/mm/swapfile.c
index a314d42c0fa..e356e5e7031 100644
--- a/mm/swapfile.c
+++ b/mm/swapfile.c
@@ -2136,6 +2136,8 @@ SYSCALL_DEFINE2(swapon, const char __user *, specialfile, int, swap_flags)
2136 atomic_inc(&proc_poll_event); 2136 atomic_inc(&proc_poll_event);
2137 wake_up_interruptible(&proc_poll_wait); 2137 wake_up_interruptible(&proc_poll_wait);
2138 2138
2139 if (S_ISREG(inode->i_mode))
2140 inode->i_flags |= S_SWAPFILE;
2139 error = 0; 2141 error = 0;
2140 goto out; 2142 goto out;
2141bad_swap: 2143bad_swap:
@@ -2163,11 +2165,8 @@ out:
2163 } 2165 }
2164 if (name) 2166 if (name)
2165 putname(name); 2167 putname(name);
2166 if (inode && S_ISREG(inode->i_mode)) { 2168 if (inode && S_ISREG(inode->i_mode))
2167 if (!error)
2168 inode->i_flags |= S_SWAPFILE;
2169 mutex_unlock(&inode->i_mutex); 2169 mutex_unlock(&inode->i_mutex);
2170 }
2171 return error; 2170 return error;
2172} 2171}
2173 2172