btrfs: use GFP_KERNEL in init_ipath
authorDavid Sterba <dsterba@suse.com>
Wed, 31 May 2017 17:32:09 +0000 (19:32 +0200)
committerDavid Sterba <dsterba@suse.com>
Mon, 19 Jun 2017 16:26:02 +0000 (18:26 +0200)
Now that init_ipath is called either from a safe context or with
memalloc_nofs protection, we can switch to GFP_KERNEL allocations in
init_path and init_data_container.

Reviewed-by: Anand Jain <anand.jain@oracle.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/backref.c
fs/btrfs/ioctl.c

index 24865da63d8fdfd2a979429a426b42fe8781e0aa..f723c11bb763b1ebd028d08d5a45151f6d897c8c 100644 (file)
@@ -16,7 +16,7 @@
  * Boston, MA 021110-1307, USA.
  */
 
-#include <linux/vmalloc.h>
+#include <linux/mm.h>
 #include <linux/rbtree.h>
 #include "ctree.h"
 #include "disk-io.h"
@@ -2305,7 +2305,7 @@ struct btrfs_data_container *init_data_container(u32 total_bytes)
        size_t alloc_bytes;
 
        alloc_bytes = max_t(size_t, total_bytes, sizeof(*data));
-       data = vmalloc(alloc_bytes);
+       data = kvmalloc(alloc_bytes, GFP_KERNEL);
        if (!data)
                return ERR_PTR(-ENOMEM);
 
@@ -2339,9 +2339,9 @@ struct inode_fs_paths *init_ipath(s32 total_bytes, struct btrfs_root *fs_root,
        if (IS_ERR(fspath))
                return (void *)fspath;
 
-       ifp = kmalloc(sizeof(*ifp), GFP_NOFS);
+       ifp = kmalloc(sizeof(*ifp), GFP_KERNEL);
        if (!ifp) {
-               vfree(fspath);
+               kvfree(fspath);
                return ERR_PTR(-ENOMEM);
        }
 
@@ -2356,6 +2356,6 @@ void free_ipath(struct inode_fs_paths *ipath)
 {
        if (!ipath)
                return;
-       vfree(ipath->fspath);
+       kvfree(ipath->fspath);
        kfree(ipath);
 }
index c9cdea8061bc46dda7a0de0e22e601bf974c245e..e4116f9248c2c1ad9c936667befe386fb31a5bc1 100644 (file)
@@ -37,7 +37,7 @@
 #include <linux/bit_spinlock.h>
 #include <linux/security.h>
 #include <linux/xattr.h>
-#include <linux/vmalloc.h>
+#include <linux/mm.h>
 #include <linux/slab.h>
 #include <linux/blkdev.h>
 #include <linux/uuid.h>
@@ -4588,7 +4588,7 @@ static long btrfs_ioctl_logical_to_ino(struct btrfs_fs_info *fs_info,
 
 out:
        btrfs_free_path(path);
-       vfree(inodes);
+       kvfree(inodes);
        kfree(loi);
 
        return ret;