aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChao Yu <chao.yu@oppo.com>2022-07-27 23:09:25 +0800
committerJaegeuk Kim <jaegeuk@kernel.org>2022-07-30 20:20:08 -0700
commitf09c2b7d4c52213d00d1635d81898ea23d3a38c9 (patch)
tree6359d8695ed1de11a6bba2a79a9438a052ae49ff
parent32e7d272344024c216f155c3463dd2d548f3fafd (diff)
downloadf2fs-tools-f09c2b7d4c52213d00d1635d81898ea23d3a38c9.tar.gz
f2fs_io: support triggering filesystem GC via ioctl
Support 'gc' sub command to trigger filesystem GC via ioctl in f2fs. Signed-off-by: Chao Yu <chao.yu@oppo.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--man/f2fs_io.83
-rw-r--r--tools/f2fs_io/f2fs_io.c28
2 files changed, 31 insertions, 0 deletions
diff --git a/man/f2fs_io.8 b/man/f2fs_io.8
index af7325a..33789c2 100644
--- a/man/f2fs_io.8
+++ b/man/f2fs_io.8
@@ -132,6 +132,9 @@ Release compressed blocks to get free space.
.TP
\fBreserve_cblocks\fR \fI[file]\fR
Reserve free blocks to prepare decompressing blocks in the file.
+.TP
+\fBgc\fR \fI[sync_mode] [file]\fR
+Trigger filesystem GC
.SH AUTHOR
This version of
.B f2fs_io
diff --git a/tools/f2fs_io/f2fs_io.c b/tools/f2fs_io/f2fs_io.c
index e735983..5be7b9e 100644
--- a/tools/f2fs_io/f2fs_io.c
+++ b/tools/f2fs_io/f2fs_io.c
@@ -1270,6 +1270,33 @@ static void do_rename(int argc, char **argv, const struct cmd_desc *cmd)
exit(0);
}
+#define gc_desc "trigger filesystem GC"
+#define gc_help "f2fs_io gc sync_mode [file_path]\n\n"
+
+static void do_gc(int argc, char **argv, const struct cmd_desc *cmd)
+{
+ u32 sync;
+ int ret, fd;
+
+ if (argc != 3) {
+ fputs("Excess arguments\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ sync = atoi(argv[1]);
+
+ fd = xopen(argv[2], O_RDONLY, 0);
+
+ ret = ioctl(fd, F2FS_IOC_GARBAGE_COLLECT, &sync);
+ if (ret < 0)
+ die_errno("F2FS_IOC_GARBAGE_COLLECT failed");
+
+ printf("trigger %s gc ret=%d\n",
+ sync ? "synchronous" : "asynchronous", ret);
+ exit(0);
+}
+
#define CMD_HIDDEN 0x0001
#define CMD(name) { #name, do_##name, name##_desc, name##_help, 0 }
#define _CMD(name) { #name, do_##name, NULL, NULL, CMD_HIDDEN }
@@ -1301,6 +1328,7 @@ const struct cmd_desc cmd_list[] = {
CMD(compress),
CMD(get_filename_encrypt_mode),
CMD(rename),
+ CMD(gc),
{ NULL, NULL, NULL, NULL, 0 }
};