David Rientjes <rientjes@xxxxxxxxxx> writes: > On Thu, 31 Aug 2017, Darrick J. Wong wrote: > >> If initializing a small swap file fails because the swap file has a >> problem (holes, etc.) then we need to free the cluster info as part of >> cleanup. Unfortunately a previous patch changed the code to use >> kvzalloc but did not change all the vfree calls to use kvfree. >> > > Hopefully this can make it into 4.13. > > Fixes: 54f180d3c181 ("mm, swap: use kvzalloc to allocate some swap data structures") > Cc: stable@xxxxxxxxxxxxxxx [4.12] > >> Found by running generic/357 from xfstests. >> >> Signed-off-by: Darrick J. Wong <darrick.wong@xxxxxxxxxx> > > Acked-by: David Rientjes <rientjes@xxxxxxxxxx> > > But I think there's also a memory leak and we need this on top of your > fix: > > > mm, swapfile: fix swapon frontswap_map memory leak on error > > Free frontswap_map if an error is encountered before enable_swap_info(). > > Signed-off-by: David Rientjes <rientjes@xxxxxxxxxx> > --- > mm/swapfile.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/mm/swapfile.c b/mm/swapfile.c > --- a/mm/swapfile.c > +++ b/mm/swapfile.c > @@ -3053,6 +3053,7 @@ SYSCALL_DEFINE2(swapon, const char __user *, specialfile, int, swap_flags) > spin_unlock(&swap_lock); > vfree(swap_map); > kvfree(cluster_info); > + kvfree(frontswap_map); > if (swap_file) { > if (inode && S_ISREG(inode->i_mode)) { > inode_unlock(inode); Yes. There is a memory leak. Reviewed-by: "Huang, Ying" <ying.huang@xxxxxxxxx> Best Regards, Huang, Ying -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>