Commit fc0e4a31 authored by Miao Xie's avatar Miao Xie Committed by root

btrfs: use GFP_NOFS instead of GFP_KERNEL

In the filesystem context, we must allocate memory by GFP_NOFS,
or we may start another filesystem operation and make kswap thread hang up.
Signed-off-by: default avatarMiao Xie <miaox@cn.fujitsu.com>
Signed-off-by: default avatarChris Mason <chris.mason@oracle.com>
parent 97d9a8a4
...@@ -471,7 +471,7 @@ static int cache_block_group(struct btrfs_block_group_cache *cache, ...@@ -471,7 +471,7 @@ static int cache_block_group(struct btrfs_block_group_cache *cache,
if (load_cache_only) if (load_cache_only)
return 0; return 0;
caching_ctl = kzalloc(sizeof(*caching_ctl), GFP_KERNEL); caching_ctl = kzalloc(sizeof(*caching_ctl), GFP_NOFS);
BUG_ON(!caching_ctl); BUG_ON(!caching_ctl);
INIT_LIST_HEAD(&caching_ctl->list); INIT_LIST_HEAD(&caching_ctl->list);
...@@ -1743,7 +1743,7 @@ static int remove_extent_backref(struct btrfs_trans_handle *trans, ...@@ -1743,7 +1743,7 @@ static int remove_extent_backref(struct btrfs_trans_handle *trans,
static void btrfs_issue_discard(struct block_device *bdev, static void btrfs_issue_discard(struct block_device *bdev,
u64 start, u64 len) u64 start, u64 len)
{ {
blkdev_issue_discard(bdev, start >> 9, len >> 9, GFP_KERNEL, 0); blkdev_issue_discard(bdev, start >> 9, len >> 9, GFP_NOFS, 0);
} }
static int btrfs_discard_extent(struct btrfs_root *root, u64 bytenr, static int btrfs_discard_extent(struct btrfs_root *root, u64 bytenr,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment