2005-12-15 14:31:24 -08:00
/* -*- mode: c; c-basic-offset: 8; -*-
* vim : noexpandtab sw = 8 ts = 8 sts = 0 :
*
* uptodate . h
*
* Cluster uptodate tracking
*
* Copyright ( C ) 2002 , 2004 , 2005 Oracle . All rights reserved .
*
* 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 the Free Software Foundation ; either
* version 2 of the License , or ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public
* License along with this program ; if not , write to the
* Free Software Foundation , Inc . , 59 Temple Place - Suite 330 ,
* Boston , MA 021110 - 1307 , USA .
*/
# ifndef OCFS2_UPTODATE_H
# define OCFS2_UPTODATE_H
2009-02-10 19:00:37 -08:00
/*
* The caching code relies on locking provided by the user of
* struct ocfs2_caching_info . These operations connect that up .
*/
struct ocfs2_caching_operations {
/*
* A u64 representing the owning structure . Usually this
* is the block number ( i_blkno or whatnot ) . This is used so
* that caching log messages can identify the owning structure .
*/
u64 ( * co_owner ) ( struct ocfs2_caching_info * ci ) ;
2009-02-10 20:00:41 -08:00
/* The superblock is needed during I/O. */
struct super_block * ( * co_get_super ) ( struct ocfs2_caching_info * ci ) ;
2009-02-10 19:00:37 -08:00
/*
* Lock and unlock the caching data . These will not sleep , and
* should probably be spinlocks .
*/
void ( * co_cache_lock ) ( struct ocfs2_caching_info * ci ) ;
void ( * co_cache_unlock ) ( struct ocfs2_caching_info * ci ) ;
/*
* Lock and unlock for disk I / O . These will sleep , and should
* be mutexes .
*/
void ( * co_io_lock ) ( struct ocfs2_caching_info * ci ) ;
void ( * co_io_unlock ) ( struct ocfs2_caching_info * ci ) ;
} ;
2005-12-15 14:31:24 -08:00
int __init init_ocfs2_uptodate_cache ( void ) ;
2006-01-07 20:07:02 +01:00
void exit_ocfs2_uptodate_cache ( void ) ;
2005-12-15 14:31:24 -08:00
2009-02-10 16:05:07 -08:00
void ocfs2_metadata_cache_init ( struct ocfs2_caching_info * ci ,
2009-02-10 19:00:37 -08:00
const struct ocfs2_caching_operations * ops ) ;
2009-02-10 20:00:41 -08:00
void ocfs2_metadata_cache_purge ( struct ocfs2_caching_info * ci ) ;
2009-02-12 15:24:40 -08:00
void ocfs2_metadata_cache_exit ( struct ocfs2_caching_info * ci ) ;
2005-12-15 14:31:24 -08:00
2009-02-10 20:00:41 -08:00
u64 ocfs2_metadata_cache_owner ( struct ocfs2_caching_info * ci ) ;
void ocfs2_metadata_cache_io_lock ( struct ocfs2_caching_info * ci ) ;
void ocfs2_metadata_cache_io_unlock ( struct ocfs2_caching_info * ci ) ;
int ocfs2_buffer_uptodate ( struct ocfs2_caching_info * ci ,
2005-12-15 14:31:24 -08:00
struct buffer_head * bh ) ;
2009-02-10 20:00:41 -08:00
void ocfs2_set_buffer_uptodate ( struct ocfs2_caching_info * ci ,
2005-12-15 14:31:24 -08:00
struct buffer_head * bh ) ;
2009-02-10 20:00:41 -08:00
void ocfs2_set_new_buffer_uptodate ( struct ocfs2_caching_info * ci ,
2005-12-15 14:31:24 -08:00
struct buffer_head * bh ) ;
2009-02-10 20:00:41 -08:00
void ocfs2_remove_from_cache ( struct ocfs2_caching_info * ci ,
2005-12-15 14:31:24 -08:00
struct buffer_head * bh ) ;
2009-02-10 20:00:41 -08:00
void ocfs2_remove_xattr_clusters_from_cache ( struct ocfs2_caching_info * ci ,
2008-08-18 17:38:47 +08:00
sector_t block ,
u32 c_len ) ;
2009-02-10 20:00:41 -08:00
int ocfs2_buffer_read_ahead ( struct ocfs2_caching_info * ci ,
2006-04-21 13:49:02 -07:00
struct buffer_head * bh ) ;
2005-12-15 14:31:24 -08:00
# endif /* OCFS2_UPTODATE_H */