[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 3/9] hw/9pfs/9p-synth: added directory for readdir test
From: |
Christian Schoenebeck |
Subject: |
[PATCH v2 3/9] hw/9pfs/9p-synth: added directory for readdir test |
Date: |
Wed, 18 Dec 2019 14:23:48 +0100 |
This will provide the following virtual files by the 9pfs
synth driver:
- /ReadDirDir/ReadDirFile99
- /ReadDirDir/ReadDirFile98
...
- /ReadDirDir/ReadDirFile1
- /ReadDirDir/ReadDirFile0
This virtual directory and its virtual 100 files will be
used by the upcoming 9pfs readdir tests.
Signed-off-by: Christian Schoenebeck <address@hidden>
---
hw/9pfs/9p-synth.c | 19 +++++++++++++++++++
hw/9pfs/9p-synth.h | 5 +++++
2 files changed, 24 insertions(+)
diff --git a/hw/9pfs/9p-synth.c b/hw/9pfs/9p-synth.c
index 54239c9bbf..7eb210ffa8 100644
--- a/hw/9pfs/9p-synth.c
+++ b/hw/9pfs/9p-synth.c
@@ -578,6 +578,25 @@ static int synth_init(FsContext *ctx, Error **errp)
NULL, v9fs_synth_qtest_flush_write,
ctx);
assert(!ret);
+
+ /* Directory for READDIR test */
+ {
+ V9fsSynthNode *dir = NULL;
+ ret = qemu_v9fs_synth_mkdir(
+ NULL, 0700, QTEST_V9FS_SYNTH_READDIR_DIR, &dir
+ );
+ assert(!ret);
+ for (i = 0; i < QTEST_V9FS_SYNTH_READDIR_NFILES; ++i) {
+ char *name = g_strdup_printf(
+ QTEST_V9FS_SYNTH_READDIR_FILE, i
+ );
+ ret = qemu_v9fs_synth_add_file(
+ dir, 0, name, NULL, NULL, ctx
+ );
+ assert(!ret);
+ g_free(name);
+ }
+ }
}
return 0;
diff --git a/hw/9pfs/9p-synth.h b/hw/9pfs/9p-synth.h
index af7a993a1e..036d7e4a5b 100644
--- a/hw/9pfs/9p-synth.h
+++ b/hw/9pfs/9p-synth.h
@@ -55,6 +55,11 @@ int qemu_v9fs_synth_add_file(V9fsSynthNode *parent, int mode,
#define QTEST_V9FS_SYNTH_LOPEN_FILE "LOPEN"
#define QTEST_V9FS_SYNTH_WRITE_FILE "WRITE"
+/* for READDIR test */
+#define QTEST_V9FS_SYNTH_READDIR_DIR "ReadDirDir"
+#define QTEST_V9FS_SYNTH_READDIR_FILE "ReadDirFile%d"
+#define QTEST_V9FS_SYNTH_READDIR_NFILES 100
+
/* Any write to the "FLUSH" file is handled one byte at a time by the
* backend. If the byte is zero, the backend returns success (ie, 1),
* otherwise it forces the server to try again forever. Thus allowing
--
2.20.1
- [PATCH v2 0/9] 9pfs: readdir optimization, Christian Schoenebeck, 2019/12/18
- [PATCH v2 9/9] hw/9pfs/9p.c: benchmark time on T_readdir request, Christian Schoenebeck, 2019/12/18
- [PATCH v2 4/9] tests/virtio-9p: added readdir test, Christian Schoenebeck, 2019/12/18
- [PATCH v2 7/9] hw/9pfs/9p-synth: avoid n-square issue in synth_readdir(), Christian Schoenebeck, 2019/12/18
- [PATCH v2 8/9] 9pfs: T_readdir latency optimization, Christian Schoenebeck, 2019/12/18
- [PATCH v2 1/9] tests/virtio-9p: add terminating null in v9fs_string_read(), Christian Schoenebeck, 2019/12/18
- [PATCH v2 2/9] 9pfs: validate count sent by client with T_readdir, Christian Schoenebeck, 2019/12/18
- [PATCH v2 6/9] 9pfs: readdir benchmark, Christian Schoenebeck, 2019/12/18
- [PATCH v2 3/9] hw/9pfs/9p-synth: added directory for readdir test,
Christian Schoenebeck <=
- [PATCH v2 5/9] tests/virtio-9p: check file names of R_readdir response, Christian Schoenebeck, 2019/12/18