* [f2fs-dev] [PATCH] f2fs_io: add fadvise support
@ 2023-10-03 22:28 Jaegeuk Kim
2023-10-07 6:38 ` Chao Yu
0 siblings, 1 reply; 2+ messages in thread
From: Jaegeuk Kim @ 2023-10-03 22:28 UTC (permalink / raw)
To: linux-f2fs-devel; +Cc: Jaegeuk Kim
f2fs_io fadvise [advice] [offset] [length] [file]
advice can be "willneed" and "sequential".
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
---
man/f2fs_io.8 | 3 +++
tools/f2fs_io/f2fs_io.c | 42 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 45 insertions(+)
diff --git a/man/f2fs_io.8 b/man/f2fs_io.8
index 99e31dd5dbd4..ecaab029d48e 100644
--- a/man/f2fs_io.8
+++ b/man/f2fs_io.8
@@ -47,6 +47,9 @@ going down with fsck mark
\fBpinfile\fR \fI[get|set] [file]\fR
Get or set the pinning status on a file.
.TP
+\fBfadvise\fR \fI[advice] [offset] [length] [file]\fR
+Pass an advice to the specified file. The advice can be willneed and sequential.
+.TP
\fBfallocate\fR \fI[-c] [-i] [-p] [-z] [keep_size] [offset] [length] [file]\fR
Request that space be allocated on a file. The
.I keep_size
diff --git a/tools/f2fs_io/f2fs_io.c b/tools/f2fs_io/f2fs_io.c
index 1f6549b46746..c812aa1458a2 100644
--- a/tools/f2fs_io/f2fs_io.c
+++ b/tools/f2fs_io/f2fs_io.c
@@ -398,6 +398,47 @@ static void do_shutdown(int argc, char **argv, const struct cmd_desc *cmd)
exit(0);
}
+#define fadvise_desc "fadvise"
+#define fadvise_help \
+"f2fs_io fadvise [advice] [offset] [length] [file]\n\n" \
+"fadvice given the file\n" \
+"advice can be\n" \
+" willneed\n" \
+" sequential\n" \
+
+static void do_fadvise(int argc, char **argv, const struct cmd_desc *cmd)
+{
+ int fd, advice;
+ off_t offset, length;
+
+ if (argc != 5) {
+ fputs("Excess arguments\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ fd = xopen(argv[4], O_RDWR, 0);
+
+ if (!strcmp(argv[1], "willneed")) {
+ advice = POSIX_FADV_WILLNEED;
+ } else if (!strcmp(argv[1], "sequential")) {
+ advice = POSIX_FADV_SEQUENTIAL;
+ } else {
+ fputs("Wrong advice\n\n", stderr);
+ fputs(cmd->cmd_help, stderr);
+ exit(1);
+ }
+
+ offset = atoi(argv[2]);
+ length = atoll(argv[3]);
+
+ if (posix_fadvise(fd, offset, length, advice) != 0)
+ die_errno("fadvise failed");
+
+ printf("fadvice %s to a file: %s\n", argv[1], argv[4]);
+ exit(0);
+}
+
#define pinfile_desc "pin file control"
#define pinfile_help \
"f2fs_io pinfile [get|set] [file]\n\n" \
@@ -1499,6 +1540,7 @@ const struct cmd_desc cmd_list[] = {
CMD(clearflags),
CMD(shutdown),
CMD(pinfile),
+ CMD(fadvise),
CMD(fallocate),
CMD(erase),
CMD(write),
--
2.42.0.582.g8ccd20d70d-goog
_______________________________________________
Linux-f2fs-devel mailing list
Linux-f2fs-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [f2fs-dev] [PATCH] f2fs_io: add fadvise support
2023-10-03 22:28 [f2fs-dev] [PATCH] f2fs_io: add fadvise support Jaegeuk Kim
@ 2023-10-07 6:38 ` Chao Yu
0 siblings, 0 replies; 2+ messages in thread
From: Chao Yu @ 2023-10-07 6:38 UTC (permalink / raw)
To: Jaegeuk Kim, linux-f2fs-devel
On 2023/10/4 6:28, Jaegeuk Kim wrote:
> f2fs_io fadvise [advice] [offset] [length] [file]
>
> advice can be "willneed" and "sequential".
>
> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Reviewed-by: Chao Yu <chao@kernel.org>
Thanks,
_______________________________________________
Linux-f2fs-devel mailing list
Linux-f2fs-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2023-10-07 6:39 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-10-03 22:28 [f2fs-dev] [PATCH] f2fs_io: add fadvise support Jaegeuk Kim
2023-10-07 6:38 ` Chao Yu
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).