mirror of
https://github.com/samba-team/samba.git
synced 2024-12-23 17:34:34 +03:00
s3:vfs:syncops add option to disable metasync per share
introduce an option to disable the metadata sync in case the filesystem handles this correctly the sync can be skipped, but synchronization of the data that was written can still be configured (in opposition to the disable flag disabling all sync operations) Autobuild-User: Volker Lendecke <vlendec@samba.org> Autobuild-Date: Fri Feb 18 17:31:59 CET 2011 on sn-devel-104
This commit is contained in:
parent
927792b212
commit
d05aa90384
@ -2,6 +2,7 @@
|
||||
* ensure meta data operations are performed synchronously
|
||||
*
|
||||
* Copyright (C) Andrew Tridgell 2007
|
||||
* Copyright (C) Christian Ambach, 2010-2011
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
@ -37,13 +38,19 @@
|
||||
syncops:onclose = no
|
||||
that can be set either globally or per share.
|
||||
|
||||
you can also disable the module completely for a service with
|
||||
On certain filesystems that only require the last data written to be
|
||||
fsync()'ed, you can disable the metadata synchronization of this module with
|
||||
syncops:onmeta = no
|
||||
This option can be set either globally or per share.
|
||||
|
||||
you can also disable the module completely for a share with
|
||||
syncops:disable = true
|
||||
|
||||
*/
|
||||
|
||||
struct syncops_config_data {
|
||||
bool onclose;
|
||||
bool onmeta;
|
||||
bool disable;
|
||||
};
|
||||
|
||||
@ -142,7 +149,7 @@ static int syncops_rename(vfs_handle_struct *handle,
|
||||
return -1);
|
||||
|
||||
ret = SMB_VFS_NEXT_RENAME(handle, smb_fname_src, smb_fname_dst);
|
||||
if (ret == 0 && !config->disable) {
|
||||
if (ret == 0 && config->onmeta && !config->disable) {
|
||||
syncops_two_names(smb_fname_src->base_name,
|
||||
smb_fname_dst->base_name);
|
||||
}
|
||||
@ -158,7 +165,7 @@ static int syncops_rename(vfs_handle_struct *handle,
|
||||
return -1); \
|
||||
ret = SMB_VFS_NEXT_ ## op args; \
|
||||
if (ret == 0 \
|
||||
&& !config->disable \
|
||||
&& config->onmeta && !config->disable \
|
||||
&& fname) syncops_name(fname); \
|
||||
return ret; \
|
||||
} while (0)
|
||||
@ -171,7 +178,7 @@ static int syncops_rename(vfs_handle_struct *handle,
|
||||
return -1); \
|
||||
ret = SMB_VFS_NEXT_ ## op args; \
|
||||
if (ret == 0 \
|
||||
&& !config->disable \
|
||||
&& config->onmeta && !config->disable \
|
||||
&& fname) syncops_smb_fname(fname); \
|
||||
return ret; \
|
||||
} while (0)
|
||||
@ -255,6 +262,9 @@ int syncops_connect(struct vfs_handle_struct *handle, const char *service,
|
||||
config->onclose = lp_parm_bool(SNUM(handle->conn), "syncops",
|
||||
"onclose", true);
|
||||
|
||||
config->onmeta = lp_parm_bool(SNUM(handle->conn), "syncops",
|
||||
"onmeta", true);
|
||||
|
||||
config->disable = lp_parm_bool(SNUM(handle->conn), "syncops",
|
||||
"disable", false);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user