@@ -2046,9 +2046,19 @@ static int btrfs_issue_clear_op(struct block_device *bdev, u64 start, u64 size,
case BTRFS_CLEAR_OP_DISCARD:
return blkdev_issue_discard(bdev, start >> 9, size >> 9,
GFP_NOFS, flags);
+ case BTRFS_CLEAR_OP_ZERO_NOUNMAP:
+ flags = BLKDEV_ZERO_NOUNMAP;
+ goto zeroout;
+ case BTRFS_CLEAR_OP_ZERO_NOFALLBACK:
+ flags = BLKDEV_ZERO_NOFALLBACK;
+ goto zeroout;
+ case BTRFS_CLEAR_OP_ZERO_NOUNMAP_NOFALLBACK:
+ flags = BLKDEV_ZERO_NOUNMAP | BLKDEV_ZERO_NOFALLBACK;
+ /* fall through */
case BTRFS_CLEAR_OP_ZERO:
+zeroout:
return blkdev_issue_zeroout(bdev, start >> 9, size >> 9,
- GFP_NOFS, 0);
+ GFP_NOFS, flags);
default:
return -EOPNOTSUPP;
}
@@ -744,6 +744,11 @@ enum btrfs_clear_op_type {
BTRFS_CLEAR_OP_DISCARD = 0,
BTRFS_CLEAR_OP_ZERO,
BTRFS_CLEAR_OP_DISCARD_SECURE,
+
+ /* Fine tuning for clearing by zeros, see __blkdev_issue_zeroout */
+ BTRFS_CLEAR_OP_ZERO_NOUNMAP,
+ BTRFS_CLEAR_OP_ZERO_NOFALLBACK,
+ BTRFS_CLEAR_OP_ZERO_NOUNMAP_NOFALLBACK,
BTRFS_NR_CLEAR_OP_TYPES,
};
Signed-off-by: David Sterba <dsterba@suse.com> --- fs/btrfs/extent-tree.c | 12 +++++++++++- include/uapi/linux/btrfs.h | 5 +++++ 2 files changed, 16 insertions(+), 1 deletion(-)