@@ -347,6 +347,7 @@ fstatfs02_64 fstatfs02_64
fsync01 fsync01
fsync02 fsync02
fsync03 fsync03
+fsync04 fsync04
ftruncate01 ftruncate01
ftruncate01_64 ftruncate01_64
@@ -1,3 +1,4 @@
/fsync01
/fsync02
/fsync03
+/fsync04
new file mode 100644
@@ -0,0 +1,60 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * Copyright (c) 2019 Linaro Limited. All rights reserved.
+ * Author: Sumit Garg <sumit.garg@linaro.org>
+ */
+
+/*
+ * fsync04
+ *
+ * It basically tests fsync() to sync test file having large dirty file pages
+ * to block device. Also, it tests all supported filesystems on a test block
+ * device.
+ */
+
+#define _GNU_SOURCE
+#include <errno.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/types.h>
+#include "tst_test.h"
+
+#define MNTPOINT "mnt_point"
+#define TST_FILE MNTPOINT"/test"
+#define TST_FILE_SIZE_MB 32
+#define SIZE_MB (1024*1024)
+#define MODE 0644
+
+static void verify_fsync(void)
+{
+ int fd;
+ unsigned long written;
+
+ fd = SAFE_OPEN(TST_FILE, O_RDWR|O_CREAT, MODE);
+
+ tst_dev_bytes_written(tst_device->dev);
+
+ tst_fill_fd(fd, 0, SIZE_MB, TST_FILE_SIZE_MB);
+
+ TEST(fsync(fd));
+
+ if (TST_RET)
+ tst_brk(TFAIL | TTERRNO, "fsync(fd) failed");
+
+ written = tst_dev_bytes_written(tst_device->dev);
+
+ SAFE_CLOSE(fd);
+
+ if (written >= SIZE_MB * TST_FILE_SIZE_MB)
+ tst_res(TPASS, "Test file synced to device");
+ else
+ tst_res(TFAIL, "Failed to sync test file to device");
+}
+
+static struct tst_test test = {
+ .needs_root = 1,
+ .mount_device = 1,
+ .all_filesystems = 1,
+ .mntpoint = MNTPOINT,
+ .test_all = verify_fsync,
+};
fsync04 tests to sync file having large dirty file pages to block device. Also, it tests all supported filesystems on a test block device. Signed-off-by: Sumit Garg <sumit.garg@linaro.org> --- runtest/syscalls | 1 + testcases/kernel/syscalls/fsync/.gitignore | 1 + testcases/kernel/syscalls/fsync/fsync04.c | 60 ++++++++++++++++++++++++++++++ 3 files changed, 62 insertions(+) create mode 100644 testcases/kernel/syscalls/fsync/fsync04.c