aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChao Yu <yuchao0@huawei.com>2020-03-06 14:38:25 +0800
committerJaegeuk Kim <jaegeuk@kernel.org>2020-03-18 18:07:18 -0700
commit596408fd82f709b2c1316df3a33d3ec8ab704394 (patch)
tree8bee16bed61df385c9b476a250cbafbe8b2c8029
parent36053752e8f8f7ee4ff9cb1b1d96098a62f44010 (diff)
downloadf2fs-tools-596408fd82f709b2c1316df3a33d3ec8ab704394.tar.gz
f2fs_io: support compress blocks ioctls
Adds to support below three commands to operate reserved blocks in compressed inode. - get_cblocks - release_cblocks - reserve_cblocks Signed-off-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--tools/f2fs_io/f2fs_io.c78
-rw-r--r--tools/f2fs_io/f2fs_io.h6
2 files changed, 84 insertions, 0 deletions
diff --git a/tools/f2fs_io/f2fs_io.c b/tools/f2fs_io/f2fs_io.c
index 68e27ed..c1edef1 100644
--- a/tools/f2fs_io/f2fs_io.c
+++ b/tools/f2fs_io/f2fs_io.c
@@ -697,6 +697,81 @@ static void do_copy(int argc, char **argv, const struct cmd_desc *cmd)
close(dst_fd);
}
+#define get_cblocks_desc "get number of reserved blocks on compress inode"
+#define get_cblocks_help "f2fs_io get_cblocks [file]\n\n"
+
+static void do_get_cblocks(int argc, char **argv, const struct cmd_desc *cmd)
+{
+ unsigned long long blkcnt;
+ int ret, fd;
+
+ if (argc != 2) {
+ fputs("Excess arguments\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ fd = xopen(argv[1], O_RDONLY, 0);
+
+ ret = ioctl(fd, F2FS_IOC_GET_COMPRESS_BLOCKS, &blkcnt);
+ if (ret < 0)
+ die_errno("F2FS_IOC_GET_COMPRESS_BLOCKS failed");
+
+ printf("%llu\n", blkcnt);
+
+ exit(0);
+}
+
+#define release_cblocks_desc "release reserved blocks on compress inode"
+#define release_cblocks_help "f2fs_io release_cblocks [file]\n\n"
+
+static void do_release_cblocks(int argc, char **argv, const struct cmd_desc *cmd)
+{
+ unsigned long long blkcnt;
+ int ret, fd;
+
+ if (argc != 2) {
+ fputs("Excess arguments\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ fd = xopen(argv[1], O_RDONLY, 0);
+
+ ret = ioctl(fd, F2FS_IOC_RELEASE_COMPRESS_BLOCKS, &blkcnt);
+ if (ret < 0)
+ die_errno("F2FS_IOC_RELEASE_COMPRESS_BLOCKS failed");
+
+ printf("%llu\n", blkcnt);
+
+ exit(0);
+}
+
+#define reserve_cblocks_desc "reserve blocks on compress inode"
+#define reserve_cblocks_help "f2fs_io reserve_cblocks [file]\n\n"
+
+static void do_reserve_cblocks(int argc, char **argv, const struct cmd_desc *cmd)
+{
+ unsigned long long blkcnt;
+ int ret, fd;
+
+ if (argc != 2) {
+ fputs("Excess arguments\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ fd = xopen(argv[1], O_RDONLY, 0);
+
+ ret = ioctl(fd, F2FS_IOC_RESERVE_COMPRESS_BLOCKS, &blkcnt);
+ if (ret < 0)
+ die_errno("F2FS_IOC_RESERVE_COMPRESS_BLOCKS failed");
+
+ printf("%llu\n", blkcnt);
+
+ exit(0);
+}
+
#define CMD_HIDDEN 0x0001
#define CMD(name) { #name, do_##name, name##_desc, name##_help, 0 }
@@ -717,6 +792,9 @@ const struct cmd_desc cmd_list[] = {
CMD(gc_urgent),
CMD(defrag_file),
CMD(copy),
+ CMD(get_cblocks),
+ CMD(release_cblocks),
+ CMD(reserve_cblocks),
{ NULL, NULL, NULL, NULL, 0 }
};
diff --git a/tools/f2fs_io/f2fs_io.h b/tools/f2fs_io/f2fs_io.h
index 3b2892c..c6ea7ff 100644
--- a/tools/f2fs_io/f2fs_io.h
+++ b/tools/f2fs_io/f2fs_io.h
@@ -68,6 +68,12 @@ typedef u32 __be32;
#define F2FS_IOC_SET_PIN_FILE _IOW(F2FS_IOCTL_MAGIC, 13, __u32)
#define F2FS_IOC_GET_PIN_FILE _IOR(F2FS_IOCTL_MAGIC, 14, __u32)
#define F2FS_IOC_PRECACHE_EXTENTS _IO(F2FS_IOCTL_MAGIC, 15)
+#define F2FS_IOC_RESIZE_FS _IOW(F2FS_IOCTL_MAGIC, 16, __u64)
+#define F2FS_IOC_GET_COMPRESS_BLOCKS _IOR(F2FS_IOCTL_MAGIC, 17, __u64)
+#define F2FS_IOC_RELEASE_COMPRESS_BLOCKS \
+ _IOR(F2FS_IOCTL_MAGIC, 18, __u64)
+#define F2FS_IOC_RESERVE_COMPRESS_BLOCKS \
+ _IOR(F2FS_IOCTL_MAGIC, 19, __u64)
#define F2FS_IOC_SET_ENCRYPTION_POLICY FS_IOC_SET_ENCRYPTION_POLICY
#define F2FS_IOC_GET_ENCRYPTION_POLICY FS_IOC_GET_ENCRYPTION_POLICY