diff options
| author | Brian Foster <bfoster@redhat.com> | 2012-06-13 12:08:38 -0400 | 
|---|---|---|
| committer | Anand Avati <avati@redhat.com> | 2012-07-13 09:46:09 -0700 | 
| commit | 32ffb79f18cbaebcbe6bba51599ca234f44675cc (patch) | |
| tree | 3f7589078e618cf0f575e5ad03a67afecb50d006 /libglusterfs/src/inode.c | |
| parent | ca4900497142127c31d0dba7a53a921200aaf790 (diff) | |
fuse/md-cache: add support for the 'fopen-keep-cache' mount option
fopen-keep-cache disables unconditional page-cache invalidations
on file open in fuse (via FOPEN_KEEP_CACHE) and replaces that
behavior with detection of remote changes and explicit
invalidations from mount/fuse. This option improves local caching
through the page cache and native client.
This change defines a new 'invalidate' translator callback to
identify when an inode's cache mapping has been determined to be
invalid. md-cache implements the policy to detect and invoke
inode invalidations. fuse-bridge and io-cache implement
invalidate handlers to invalidate the respective caches (page
cache in the case of fuse).
BUG: 833564
Change-Id: I99818da5777eaf06276c1c0b194669f5bab92d48
Signed-off-by: Brian Foster <bfoster@redhat.com>
Reviewed-on: http://review.gluster.com/3584
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Anand Avati <avati@redhat.com>
Diffstat (limited to 'libglusterfs/src/inode.c')
| -rw-r--r-- | libglusterfs/src/inode.c | 48 | 
1 files changed, 48 insertions, 0 deletions
diff --git a/libglusterfs/src/inode.c b/libglusterfs/src/inode.c index e32eddb5d1c..a0088c03c55 100644 --- a/libglusterfs/src/inode.c +++ b/libglusterfs/src/inode.c @@ -950,6 +950,54 @@ inode_forget (inode_t *inode, uint64_t nlookup)          return 0;  } +/* + * Invalidate an inode. This is invoked when a translator decides that an inode's + * cache is no longer valid. Any translator interested in taking action in this + * situation can define the invalidate callback. + */ +int +inode_invalidate(inode_t *inode) +{ +	int ret = 0; +	xlator_t *xl = NULL; +	xlator_t *old_THIS = NULL; + +	if (!inode) { +		gf_log_callingfn(THIS->name, GF_LOG_WARNING, "inode not found"); +		return -1; +	} + +	/* +	 * The master xlator is not in the graph but it can define an invalidate +	 * handler. +	 */ +	xl = inode->table->xl->ctx->master; +	if (xl && xl->cbks->invalidate) { +		old_THIS = THIS; +		THIS = xl; +		ret = xl->cbks->invalidate(xl, inode); +		THIS = old_THIS; +		if (ret) +			return ret; +	} + +	xl = inode->table->xl->graph->first; +	while (xl) { +		old_THIS = THIS; +		THIS = xl; +		if (xl->cbks->invalidate) +			ret = xl->cbks->invalidate(xl, inode); +		THIS = old_THIS; + +		if (ret) +			break; + +		xl = xl->next; +	} + +	return ret; +} +  static void  __inode_unlink (inode_t *inode, inode_t *parent, const char *name)  | 
