From 1cb18e1e0de4873f98c58e23e1ed133c3914272f Mon Sep 17 00:00:00 2001 From: Samuel Thibault Date: Sat, 22 Sep 2012 23:45:28 +0200 Subject: Avoid waiting for disk I/O completion This improves performance quite a bit, and is not less safe. * ext2fs/dir.c (diskfs_direnter_hard, diskfs_dirremove_hard, diskfs_dirrewrite_hard): Pass diskfs_synchronous instead of 1 as wait parameter to diskfs_file_update. * ext2fs/truncate.c (diskfs_truncate): Likewise. * libdiskfs/dir-init.c (diskfs_init_dir): Likewise. * libdiskfs/dir-link.c (diskfs_S_dir_link): Likewise. * libdiskfs/dir-rename.c (diskfs_S_dir_rename): Likewise. * libdiskfs/dir-renamed.c (diskfs_rename_dir): Likewise. * libdiskfs/file-set-trans.c (diskfs_S_file_set_translator): Likewise. * libdiskfs/node-create.c (diskfs_create_node): Likewise. * libdiskfs/node-drop.c (diskfs_drop_node): Likewise. --- ext2fs/truncate.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'ext2fs/truncate.c') diff --git a/ext2fs/truncate.c b/ext2fs/truncate.c index 077225b0..2058a1c1 100644 --- a/ext2fs/truncate.c +++ b/ext2fs/truncate.c @@ -294,7 +294,7 @@ diskfs_truncate (struct node *node, off_t length) node->dn_stat.st_size = length; node->dn_set_mtime = 1; node->dn_set_ctime = 1; - diskfs_node_update (node, 1); + diskfs_node_update (node, diskfs_synchronous); return 0; } @@ -309,6 +309,7 @@ diskfs_truncate (struct node *node, off_t length) { diskfs_node_rdwr (node, (void *)zeroblock, length, block_size - offset, 1, 0, 0); + /* Make sure that really happens to avoid leaks. */ diskfs_file_update (node, 1); } @@ -323,7 +324,7 @@ diskfs_truncate (struct node *node, off_t length) node->dn_stat.st_size = length; node->dn_set_mtime = 1; node->dn_set_ctime = 1; - diskfs_node_update (node, 1); + diskfs_node_update (node, diskfs_synchronous); err = diskfs_catch_exception (); if (!err) -- cgit v1.2.3