2019-05-28 19:57:16 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2013-08-22 01:29:54 +04:00
/*
* Ceph cache definitions .
*
* Copyright ( C ) 2013 by Adfin Solutions , Inc . All Rights Reserved .
* Written by Milosz Tanski ( milosz @ adfin . com )
*/
# ifndef _CEPH_CACHE_H
# define _CEPH_CACHE_H
2020-06-01 17:10:21 +03:00
# include <linux/netfs.h>
2013-08-22 01:29:54 +04:00
# ifdef CONFIG_CEPH_FSCACHE
2013-09-06 19:13:18 +04:00
extern struct fscache_netfs ceph_cache_netfs ;
2013-08-22 01:29:54 +04:00
int ceph_fscache_register ( void ) ;
void ceph_fscache_unregister ( void ) ;
2019-03-25 19:38:32 +03:00
int ceph_fscache_register_fs ( struct ceph_fs_client * fsc , struct fs_context * fc ) ;
2013-08-22 01:29:54 +04:00
void ceph_fscache_unregister_fs ( struct ceph_fs_client * fsc ) ;
2016-05-18 10:25:03 +03:00
void ceph_fscache_register_inode_cookie ( struct inode * inode ) ;
2013-08-22 01:29:54 +04:00
void ceph_fscache_unregister_inode_cookie ( struct ceph_inode_info * ci ) ;
2016-05-18 10:25:03 +03:00
void ceph_fscache_file_set_cookie ( struct inode * inode , struct file * filp ) ;
2016-05-18 15:31:55 +03:00
void ceph_fscache_revalidate_cookie ( struct ceph_inode_info * ci ) ;
2013-08-22 01:29:54 +04:00
int ceph_readpage_from_fscache ( struct inode * inode , struct page * page ) ;
int ceph_readpages_from_fscache ( struct inode * inode ,
struct address_space * mapping ,
struct list_head * pages ,
unsigned * nr_pages ) ;
2016-05-18 15:31:55 +03:00
static inline void ceph_fscache_inode_init ( struct ceph_inode_info * ci )
{
ci - > fscache = NULL ;
}
2013-08-22 01:29:54 +04:00
2020-06-01 17:10:21 +03:00
static inline struct fscache_cookie * ceph_fscache_cookie ( struct ceph_inode_info * ci )
{
return ci - > fscache ;
}
2013-08-22 01:29:54 +04:00
static inline void ceph_fscache_invalidate ( struct inode * inode )
{
fscache_invalidate ( ceph_inode ( inode ) - > fscache ) ;
}
2020-06-01 17:10:21 +03:00
static inline bool ceph_is_cache_enabled ( struct inode * inode )
{
struct fscache_cookie * cookie = ceph_fscache_cookie ( ceph_inode ( inode ) ) ;
if ( ! cookie )
return false ;
return fscache_cookie_enabled ( cookie ) ;
}
static inline int ceph_begin_cache_operation ( struct netfs_read_request * rreq )
{
struct fscache_cookie * cookie = ceph_fscache_cookie ( ceph_inode ( rreq - > inode ) ) ;
return fscache_begin_read_operation ( rreq , cookie ) ;
}
2013-08-22 01:29:54 +04:00
# else
static inline int ceph_fscache_register ( void )
{
return 0 ;
}
static inline void ceph_fscache_unregister ( void )
{
}
2019-03-25 19:38:32 +03:00
static inline int ceph_fscache_register_fs ( struct ceph_fs_client * fsc ,
struct fs_context * fc )
2013-08-22 01:29:54 +04:00
{
return 0 ;
}
static inline void ceph_fscache_unregister_fs ( struct ceph_fs_client * fsc )
{
}
static inline void ceph_fscache_inode_init ( struct ceph_inode_info * ci )
{
}
2020-06-01 17:10:21 +03:00
static inline struct fscache_cookie * ceph_fscache_cookie ( struct ceph_inode_info * ci )
{
return NULL ;
}
2016-05-18 10:25:03 +03:00
static inline void ceph_fscache_register_inode_cookie ( struct inode * inode )
{
}
static inline void ceph_fscache_unregister_inode_cookie ( struct ceph_inode_info * ci )
{
}
static inline void ceph_fscache_file_set_cookie ( struct inode * inode ,
struct file * filp )
2013-08-22 01:29:54 +04:00
{
}
static inline void ceph_fscache_invalidate ( struct inode * inode )
{
}
2020-06-01 17:10:21 +03:00
static inline bool ceph_is_cache_enabled ( struct inode * inode )
{
return false ;
}
static inline int ceph_begin_cache_operation ( struct netfs_read_request * rreq )
{
return - ENOBUFS ;
}
2013-08-22 01:29:54 +04:00
# endif
2021-01-21 20:32:05 +03:00
# endif /* _CEPH_CACHE_H */